Wo3schoo| 
MongoDB 


教程 


wizardforcel 





W3School MongoDB 教程 


וב 


NoSQL 简介 

什么 是 MongoDB ? 

window 平 台 安装 MongoDB 

Linux 平 台 安装 MongoDB 

MongoDB 数据 库 ， 对 象 ， 集 合 
MongoDB - 连接 

PHP 安 装 MongoDB 扩 展 驱 动 
MongoDB 数据 插入 
MongoDB 使 用 update() 函 数 更 新 数据 
MongoDB 使 用 - remove() 范 数 删 除数 据 
MongoDB 查询 
MongoDB 条 件 操 作 符 
MongoDB 条 件 操 作 符 - $type 
MongoDB Limit 与 Skip 方 法 
MongoDB 排序 

MongoDB 索引 

MongoDB 聚合 

MongoDB 复制 (副本 集 ) 

MongoDB 分 片 


MongoDB 各 份 (mongodump) 与 恢复 (mongorerstore) 


MongoDB 监控 
MongoDB Java 
MongoDB PHP 
MongoDB 关系 
MongoDB 数据 库 引 用 
MongoDB 覆盖 索引 查询 
MongoDB 查询 分 析 
MongoDB 原子 操作 
MongoDB 高 级 索引 


(OO ₪004 ₪ oo 上 wm ₪ 


W3School MongoDB 教程 


MongoDB 索引 限制 

MongoDB Objectld 

MongoDB Map Reduce 

MongoDB 全 文 检索 

MongoDB 正则 表达 式 

MongoDB 管理 工具 : Rockmongo 
MongoDB GridFS 

MongoDB 固定 集合 (Capped Collections) 
MongoDB 自动 增长 

免责 声明 


30 
31 
32 
33 
34 
35 
36 
37 
38 
39 


W3School MangoDB 教 程 


来 源 : MongoDB 教 程 


整理 : 飞龙 


NoSQL 简介 


NoSQL(NoSQL = Not Only SQL )， 意 即 " 不 仅仅 是 SQL"。 
在 现代 的 计算 系统 上 每 天 网 络 上 都 会 产生 庞大 的 数据 量 。 


这 些 数据 有 很 大 一 部 分 是 由 关系 数据 库 管 理 系统 (RDMBSs) 来 处 理 。 1970 年 E.F.Codd's 提 
出 的 关系 模型 的 论文 "Arelational model of data for large shared data banks"， 这 使 得 数据 建 
模 和 应 用 程序 编程 更 加 简单 。 


通过 应 用 实践 证 明 ， 关 系 模型 是 非常 适合 于 客户 服务 器 编程 ， 远 远 超出 预期 的 利益 ， 今 天 它 
是 结构 化 数据 存储 在 网 络 和 商务 应 用 的 主导 技术 。 


NoSQL 是 一 项 全 新 的 数据 库 革 命 性 运动 ， 早 期 就 有 人 提出 ， 发 展 至 2009 年 趋势 越发 高 涨 。 
NoSQL 的 拥护 者 们 提倡 运用 非 关系 型 的 数据 存储 ， 相 对 于 铺天盖地 的 关系 型 数据 库 运 用 ， 这 
一 概念 无 疑 是 一 种 全 新 的 思维 的 注入。 


关系 型 数据 库 尊 循 ACID 规 则 


事务 在 英文 中 是 transaction， 和 现实 世界 中 的 交易 很 类 似 ， 它 有 如 下 四 个 特性 : 


1、A (Atomicity) 原子 性 
原子 性 很 容易 理解 ， 也 就 是 说 事务 里 的 所 有 操作 要 么 全 部 做 完 ， 要 么 都 不 做 ， 事 务 成 功 的 条 
件 是 事务 里 的 所 有 操作 都 成 功 ， 只 要 有 一 个 操作 失败 ， 整 个 事务 就 失败 ， 需 要 回 滚 。 


比如 银行 转账 ， 从 A 账 户 转 100 元 至 B 账 户 ， 分 为 两 个 步骤 : 1) 从 A 账户 取 100 元 ; 2) 存 入 
100 元 至 B 账 户 。 这 两 步 要 么 一 起 完成 ， 要 么 一 起 不 完成 ， 如 果 只 完成 第 一 步 ， 第 二 步 失 败 ， 
钱 会 莫名 其 妙 少 了 100 元 。 


2、C (Consistency) 一 致 性 
一 致 性 也 比较 容易 理解 ， 也 就 是 说 数据 库 要 一 直 久 于 一 致 的 状态 ， 事 务 的 运行 不 会 改变 数据 
库 原 本 的 一 致 性 约束 。 


例如 现 有 完整 性 约束 atb=10， 如 果 一 个 事务 改变 了 a， 那 么 必须 得 改变 0b， 使 得 事务 结束 后 依 
然 满 足 a+b=10， 否 则 事务 失败 。 


3、1 (lsolation) 独立 性 

所 谓 的 独立 性 是 指 并 发 的 事务 之 间 不 会 互相 影响 ， 如 果 一 个 事务 要 访问 的 数据 正在 被 另外 一 
个 事务 修改 ， 只 要 另外 一 个 事务 未 提交 ， 它 所 访问 的 数据 就 不 受 未 提交 事务 的 影响 。 

比如 现 有 有 个 交易 是 从 A 账户 转 100 元 至 B 账 户 ， 在 这 个 交易 还 未 完成 的 情况 下 ， 如 果 此 时 B 查 
询 自 己 的 账户 ， 是 看 不 到 新 增加 的 100 元 的 。 


4、D (Durability) 持久 性 
持久 性 是 指 一 旦 事务 提交 后 ， 它 所 做 的 修改 将 会 永久 的 保存 在 数据 库 上 ， 即 使 出 现 宕 机 也 不 
会 丢失 。 


分 布 式 系统 
分 布 式 系统 (distributed system) 由 多 台 计 算 机 和 通信 的 软件 组 件 通 过 计算 机 网 络 连 接 (本 
地 网 络 或 广域网 ) 组 成 。 


分 布 式 系统 是 建立 在 网 络 之 上 的 软件 系统 。 正 是 因为 软件 的 特性 ， 所 以 分 布 式 系统 具有 高 度 
的 内 聚 性 和 透明 性 。 


因此 ， 网 络 和 分 布 式 系统 之 间 的 区 别 更 多 的 在 于 高 层 软 件 (特别 是 操作 系统 ) ， 而 不 是 硬 
件 。 


分 布 式 系统 可 以 占用 在 在 不 同 的 平台 上 如 : Pe、 工作 站 、 局 域 网 和 广域网 上 等 。 
分 布 式 计算 的 优点 
可 靠 性 (容错 ) 


分 布 式 计算 系统 中 的 一 个 重要 的 优点 是 可 靠 性 。 一 台 服 务 器 的 系统 崩溃 并 不 影响 到 其 余 的 服 
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可 扩展 性 : 

在 分 布 式 计算 系统 可 以 根据 需要 增加 更 多 的 机 器 。 

资源 共享 : 

共享 数据 是 必 不 可 少 的 应 用 ， 如 银行 ， 预 订 有 系统 。 

灵活 性 : 

由 于 该 系统 是 非常 灵活 的 ， 它 很 容易 安装 ， 实 施 和 调试 新 的 服务 。 
更 快 的 速度 : 

分 布 式 计算 系统 可 以 有 多 台 计 算 机 的 计算 能 力 ， 使 得 它 比 其 他 系统 有 更 快 的 处 理 速度 。 
开放 系统 : 

由 于 它 是 开放 的 系统 ， 本 地 或 者 远程 都 可 以 访问 到 该 服务 。 
更 高 的 性 能 : 


相 较 于 集中 式 计算 机 网 络 集群 可 以 提供 更 高 的 性 能 (及 更 好 的 性 价 比 ) 。 


分 布 式 计算 的 缺点 


故障 排除 : 
故障 排除 和 诊断 问题 。 


软件 : 
更 少 的 软件 支持 是 分 布 式 计算 系统 的 主要 缺点 。 


网 络 : 
网 络 基础 设施 的 问题 ， 包 括 : 传输 问题 ， 高 负载 ， 信 息 丢 失 等 。 


安全 性 : 
开发 系统 的 特性 让 分 布 式 计 算 系 统 存在 着 数据 的 安全 性 和 共享 的 风险 等 问题 。 


什么 是 NoSQL? 
NoSQL， 指 的 是 非 关 系 型 的 数据 库 。NoSQL 有 时 也 称 作 Not Only SQL 的 缩写 ， 是 对 不 同 于 伟 
统 的 关系 型 数据 库 的 数据 库 管 理 系统 的 统称 。 


NoSQL 用 于 超大 规模 数据 的 存储 。 (例如 谷歌 或 Facebook 每 天 为 他 们 的 用 户 收集 万 亿 比 特 的 
数据 ) 。 这 些 类 型 的 数据 存储 不 需要 固定 的 模式 ， 无 需 多 余 操 作 就 可 以 横向 扩展 。 


为 什么 使 用 NoSQL ? 


今天 我 们 可 以 通过 第 三 方 平台 (如 : Google,Facebook 等 ) 可 以 很 容易 的 访问 和 抓 取 数据 。 用 
户 的 个 人 信息 ， 社 交 网 络 ， 地 理 位 置 ， 用 户 生 成 的 数据 和 用 户 操作 日 志 已 经 成 倍 的 增加 。 我 
们 如 果 要 对 这 些 用 户 数据 进行 挖掘 ， 那 SQL 数据 库 已 经 不 适合 这 些 应 用 了 , NoSQL 数 据 库 的 发 
展 也 却 能 很 好 的 处 理 这 些 大 的 数据 。 
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实例 
社会 化 关系 网 : 


Each record: UserID1, UserID2 
Separate records: UserID, first_name,1last_name, age, gender,... 
Task: Find all friends of friends of friends of ... friends of a given user. 


Wikipedia 页 面 : 


Large collection of documents 
Combination of structured and unstructured data 
Task: Retrieve all pages regarding athletics of Summer Olympic before 1950. 


RDBMS vs NoSQL 


RDBMS 


。 高 度 组 织 化 结构 化 数据 

。 结构 化 查询 语言 (SQL) (SQL) 
。 数据 和 关系 都 存储 在 单独 的 表 中 。 
。 数据 操纵 语言 ， 数 据 定义 语言 
。 严格 的 一 致 性 

。 基础 事务 


NoSQL 


。 代表 着 不 仅仅 是 SQL 
* 没有 声明 性 查询 语言 
* 没有 预定 义 的 模式 
- 键 - 值 对 存储 ， 列 存储 ， 文 档 存 储 ， 图 形 数据 谭 
。 最 终 一 致 性 ， 而 非 ACID 属 性 
* 非 结构 化 和 不 可 预知 的 数据 
. CAP 定 理 
。 高 性 能 ， 高 可 用 性 和 可 伸缩 性 
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Unstructured and 
Semi-Structured Data 


0,8 Text, Log Files, 
Click Streams, 
0.6 Blogs, Tweets， 
Audio, Video, etc. 
04 Structured Data 
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NoSQL 5: 


NoSQL 一 词 最 早出 现 于 1998 年 ， 是 Carlo Strozzi 开 发 的 一 个 轻 量 、 开 源 、 不 提供 SQL 功 能 区 
关系 数据 库 。 


2009 年 ，Last.fm 的 Johan Oskarsson 发 起 了 一 次 关于 分 布 式 开源 数据 库 的 讨论 [2]， 来 自 
Rackspace 的 Eric Evans 再 次 提出 了 NoSQL 的 概念 ， 这 时 的 NoSQL 主 要 指 非 关 系 型 、 分 布 
式 、 不 提供 ACID 的 数据 库 设 计 模 式 。 


2009 年 在 亚特兰大 举行 的 "no:sql(east)" 讨 论 会 是 一 个 里 程 碑 ， 其 口号 是 "select fun, profit from 
real_world where relational=false;"。 因 此 ， 对 NoSQL 最 普通 的 解释 是 " 非 关联 型 的 "， 强 调 
Key-Value Stores 和 文档 数据 库 的 优点 ， 而 不 是 单纯 的 反对 RDBMS。 


CAP 定 理 (CAP theorem) 


在 计算 机 科学 中 , CAP 定 理 (CAP theorem) , 又 被 称 作 布 鲁 尔 定理 (Brewers theorem) , 它 
指出 对 于 一 个 分 布 式 计 算 系 统 来 说 ， 不 可 能 同时 满足 以 下 三 点 : 


。 一 致 性 (Consistency) (所 有 节点 在 同一 时 间 有 具有 相同 的 数据 ) 
。 可 用 性 (Availability) (保证 每 个 请 求 不 管 成 功 或 者 失败 都 有 响应 ) 
。 分 隔 容忍 (Partition tolerance) (系统 中 任意 信息 的 丢失 或 失败 不 会 影响 系统 的 继续 运作 ) 


CAP 理 论 的 核心 是 : 一 个 分 布 式 系统 不 可 能 同时 很 好 的 满足 一 致 性 ， 可 用 性 和 分 区 容错 性 这 
三 个 需求 ， 最 多 只 能 同时 较 好 的 满足 两 个 。 


因此 ， 根 据 CAP 原理 将 NoSQL 数据 库 分 成 了 满足 CA 原则 、 满 足 CP 原则 和 满足 AP 原则 
三 大 类 : 


。 CA - 单 点 集群 ， 满 足 一 致 性 ， 可 用 性 的 系统 ， 通 常 在 可 扩展 性 上 不 太 强 大 。 
。 CP - 满足 一 致 性 ， 分 区 容忍 必 的 系统 ， 通 常 性 能 不 是 特别 高 。 
。 AP - 满足 可 用 性 ， 分 区 容忍 性 的 系统 ， 通 常 可 能 对 一 致 性 要 求 低 一 些 。 


CAP Theorem 


Consistency MongoDB 


HBase 
4 Redis 


CA CP 


Partition 
Tolerance 


CouchDB 
Cassandra 
DynamoDB 

Riak 





NoSQL 的 优点 /缺点 


优点 
。 高 可 扩展 性 
。 分 布 式 计算 
。 低 成 本 
。 架构 的 灵活 性 ， 半 结构 化 数据 
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0 没有 复杂 的 关系 


o。 没有 标准 化 
0 有限 的 查询 功能 (到 目前 为 止 ) 


0 最 终 一 致 是 不 直观 的 程序 


BASE 


BASE : Basically Available, Soft-state, Eventually Consistent。 由 Eric Brewer 定义 。 


CAP 理 论 的 核心 是 : 一 个 分 布 式 系统 不 可 能 同时 很 好 的 满足 一 致 性 ， 可 用 性 和 分 区 容错 性 这 
三 个 需求 ， 最 多 只 能 同时 较 好 的 满足 两 个 。 
BASE 是 NoSQL 数 据 库 通常 对 可 用 性 及 一 致 性 的 弱 要 求 原则 : 
。 Basically Availble -- 基 本 可 用 
* Soft-state -- 软 状态 /柔性 事务 。 "Soft state" 可 以 理解 为 "无 连接 "的 , 而 "Hard state" "₪ 
向 连接 "的 


。 Eventual Consistency -- 最 终 一 致 性 最 终 一 致 性 ， 也 是 是 ACID 的 最 终 目 的 。 


ACID vs BASE 


ACID BASE 
原子 性 (Atomicity) 基本 可 用 (Basically Available) 
一 致 性 (Consistency) 软 状态 /柔性 事务 (Soft state) 
隔离 性 (lsolation) 最 终 一 致 性 (Eventual consistency) 
持久 性 (Durable) 


NoSQL 数据 库 分 类 


类 型 部 分 代表 


列 存 Hbase Cassandra 


Hypertable 


文档 MongoDB 
存储 CouchDB 


Tokyo Cabinet / 


Tyrant Berkeley DB 

value 

存储 MemcacheDB 
Redis 

国 全 od 8 
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对 象 

存储 db4o Versant 
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库 BaseX 


谁 在 使 用 


现在 已 经 有 很 多 公司 使 用 了 NoSQ : 


Google 

Facebook 

Mozilla 

Adobe 

Foursquare 

Linkedln 

Digg 

McGraw-Hill Education 
Vermont Public Radio 


特点 


顾名思义 ， 是 按 列 存储 数据 的 。 最 大 的 特点 是 方便 存储 
结构 化 和 半 结 构 化 数据 ， 方 便 做 数据 压缩 ， 对 针对 某 一 
列 或 者 某 几 列 的 查询 有 非常 大 的 IO 优势 。 


文档 存储 一 般 用 类 似 json 的 格式 存储 ， 存 储 的 内 容 是 
档 型 的 。 这 样 也 就 有 有 机 会 对 某 些 字段 建立 索引 ， 实 现 
关系 数据 库 的 某 些 功能 。 


可 以 通过 key 快 速 查询 到 其 value。 一 般 来 说 ， 存 储 不 管 
value 的 格式 ， 照 单 全 收 。 (Redis 包 含 了 其 他 功能 ) 


图 形 关 系 的 最 佳 存储 。 使 用 传统 关系 数据 库 来 解决 的 话 
性 能 低下 ， 而 且 设 计 使 用 不 方便 。 

通过 类 似 面向 对 象 语言 的 语法 操作 数据 库 ， 通 过 对 象 的 
方式 存 取 数 据 。 


高 效 的 存储 XML 数据 ， 并 支持 XML 的 内 部 查询 语法 ， 比 
如 XQuery,Xpath。 


什么 是 MongoDB ? 


MongoDB 是 由 C++ 语言 编写 的 开源 数据 库 系 统 。 
在 高 负载 的 情况 下 ， 添 加 更 多 的 节点 ， 可 以 保证 服务 器 性 能 。 


MongoDB 旨 在 为 WEB 问 用 提供 可 扩展 的 高 性 能 数据 存储 解决 方案 。 





MongoDB 将 数据 存储 为 一 个 文档 。MongoDB 是 一 个 基于 分 布 式 文件 存储 的 数据 库 。 


FirstName="Arun", Address="St. Xavier's Road", Spouse=[{Name:"Kiran"}], Children=[{Name:" 
FirstName="Sameer",Address="8 Gandhi Road " . 
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注意 : 以 上 数据 有 两 个 不 同 的 文档 (以 "." 分 隔 ) 。 以 这 种 方式 存储 数据 即 为 文件 存储 的 数据 
库 。 MongoDB 是 一 个 面向 文档 的 数据 库 。 





主要 特 氮 


。 MongoDB 的 提供 了 一 个 面向 文档 存储 ， 操 作 起 来 比较 简单 和 容易 。 

。 你 可 以 在 MongoDB 记 录 中 设置 任何 属性 的 索引 (如 : FirstName="Sameer",Address="8 
Gandhi Road") 来 实现 更 快 的 排序 。 

。 你 可 以 通过 本 地 或 者 网 络 创建 数据 镜像 ， 这 使 得 MongoDB 有 更 强 的 扩展 性 。 

。 如 果 负 载 的 增加 (需要 更 多 的 存储 空间 和 更 强 的 处 理 能 力 ) ， 它 可 以 分 布 在 计算 机 网 络 
中 的 其 他 节点 上 这 就 是 所 谓 的 分 片 。 

。 Mongo 支 持 丰富 的 查询 表达 式 。 查 询 指令 使 用 JSON 形 式 的 标记 ， 可 轻易 查询 文档 中 内 族 
的 对 象 及 数组 。 

。 MongoDb 使 用 update() 命 合 可 以 实现 替换 完成 的 文档 (数据 ) 或 者 一 些 指 定 的 数据 字段 

。 Mongodb 中 的 Map/reduce 主 要 是 用 来 对 数据 进行 批量 处 理 和 聚合 操作 。 

> Map 和 Reduce。 Map 画 数 调 用 emit(key,value) 表 万 集合 中 所 有 的 记录 ， 将 key 与 value 传 
给 Reduce 辑 数 进行 处 理 。 

> Map 画 数 和 Reduce 郴 数 是 使 用 Javascript 编 写 的 ， 并 可 以 通过 db.runCommand 或 
mapreduce 命 令 来 执行 MapReduce 操 作 。 

* GridFS 是 MongoDB 中 的 一 个 内 置 功能 ， 可 以 用 于 存放 大 量 小 文件 。 


MongoDB 人 允许 在 服务 端 执 行 脚本 ， 可 以 用 Javascript 编 写 某 个 函数 ， 直 接 在 服务 端 执 
行 ， 也 可 以 把 函数 的 定义 存储 在 服务 端 ， 下 次 直接 调用 即 可 。 
MongoDB 支 持 各 种 编程 语言 :RUBY，PYTHON，JAVA，C++，PHP，0C# 等 多 种 语言 。 


> 1 רק 


6 ₪ 3 םסספחסו 


历史 2007 年 10 月 ，MongoDB 由 10gen 团 队 所 发 展 。2009 年 2 月 首 度 推出 。 


2012 年 05 月 23 日 ，MongoDB2.1 开发 分 支 发 布 了 ! 该 版 本 采用 全 新 架构 ， 包 含 诸 多 增 
6 

2012 年 06 月 06 日 ，MongoDB 2.0.6 发 布 ， 分 布 式 文档 数据 库 。 

2013 年 04 月 23 日 ，MongoDB 2.4.3 发 布 ， 此 版 本 包括 了 一 些 性 能 优化 ， 功 能 增强 以 及 
bug 修 复 。 

2013 年 08 月 20 日 ，MongoDB 2.4.6 发 布 ， 是 目前 最 新 的 稳定 版 。 


MongoDB 下 载 


你 可 以 在 mongodb 官 网 下 载 该 安装 包 ， 地 址 为 : http://www.mongodb.org/downloads。 
MonggoDB 支 持 以 下 平台 : 


OS X 32-bit 
OS X 64-bit 
Linux 32-bit 
Linux 64-bit 
Windows 32-bit 
Windows 64-bit 
Solaris i86pc 
Solaris 64 


MongoDB 工具 


有 几 种 可 用 于 MongoDB 的 管理 工具 。 


监控 


MongoDB 提 供 了 网 络 和 系统 监控 工具 Munin， 它 作为 一 个 插件 应 用 于 MongoDB 中 。 


Gangila 是 MongoDB 高 性 能 的 系统 监视 的 工具 ， 它 作为 一 个 插件 应 用 于 MongoDB 中 。 


基于 图 形 界面 的 开源 工具 Cacti, 用 于 查看 CPU 负载 , 网 络 带 宽 利 用 率 , 它 也 提供 了 一 个 应用 于 
监控 MongoDB 的 插件 。 


GUI 


Fang of Mongo 一 网 页 式 ,由 Django 和 jQuery 所 构成 。 

Futon4Mongo - 一 个 CouchDB Futon web 的 mongodb 山 寨 版 。 

Mongo3 - Ruby 写 成 。 

MongoHub - 适用 于 OSX 的 应 用 程序 。 

Opricot - 一 个 基于 浏览 器 的 MongoDB 控 制 台 , 由 PHP 撰 写 而 成 。 

Database Master 一 Windows 的 mongodb 管 理工 具 

RockMongo 一 最 好 的 PHP 语 言 的 MongoDB 管 理工 具 ， 轻 量 级 , 支持 多 国语 言 . 


MongoDB 应 用 案例 


下 面 列举 一 些 公司 MongoDB 的 实际 应 用 : 


Craiglist 上 使 用 MongoDB 的 存档 数 十 亿 条 记录 。 

FourSquare， 基 于 位 置 的 社交 网 站 ， 在 Amazon EC2 的 服务 器 上 使 用 MongoDB 分 享 数 
据 。 

Shutterfly， 以 互联 网 为 基础 的 社会 和 个 人 出 版 服务 ， 使 用 MongoDB 的 各 种 持久 性 数据 存 
储 的 要 求 。 

bit.ly, 一 个 基于 Web 的 网 址 缩短 服务 ， 使 用 MongoDB 的 存储 自己 的 数据 。 

spike.com， 一 个 MTV 网 络 的 联营 公司 ， spike.com 使 用 MongoDB 的 。 

Intuit 公 司 ， 一 个 为 小 企业 和 个 人 的 软件 和 服务 提供 商 ， 为 小 型 企业 使 用 MongoDB 的 跟踪 
用 户 的 数据 。 

sourceforge.net， 资 源 网 站 查找 ， 创 建 和 发 布 开源 软件 免费 ， 使 用 MongoDB 的 后 端 存 
储 。 

etsy.com ， 一 个 购买 和 出 售 手工 制作 物品 网 站 ， 使 用 MongoDB。 

纽约 时 报 ， 领 先 的 在 线 新 闻 门 户 网 站 之 一 ， 使 用 MongoDB。 

CERN， 著 名 的 粒子 物理 研究 所 ， 欧 洲 核子 研究 中 心 大 型 强 子 对 撞 机 的 数据 使 用 
MongoDB。 


window 平 台 安 六 MongoDB 


MongoDB 下 载 

MongoDB 提 供 了 可 用 于 32 位 和 64 位 系统 的 预 编译 二 进 制 包 ， 你 可 以 从 MongoDB 官 网 下 载 安 
装 ，MongoDB 预 编译 二 进 制 包 下 载 地 址 : 

http://www.mongodb.org/downloads 


05 א‎ 32-01 QSX54-bit שחו‎ 32-bit Linux64d-bit Windows 22-bt Windows 54-bit Solaris i8Epc Solafis 64 Source 
nats "ole nole ncte 
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5MH72011 חא‎ 6 0 :gz 
dovrlcad dowrioad dwn 0ad חצ‎ 6 
changslog "legacy-atatic + zp 


melsa3e Noles 


解压 
下 载 zip 包 后 ， 解 压 安 装 包 ， 并 安装 它 。 
创建 数据 目录 


MongoDB 将 数据 目录 存储 在 db 目录 下 。 但 是 这 个 数据 目录 不 会 主动 创建 ， 我 们 在 安装 完成 
后 需要 创建 它 。 请 注意 ， 数 据 目 录 应 该 抽奖 在 根 目录 下 〈( 如 : CA 或 者 \ם‎ 等 )。 


在 本 教程 中 ， 我 们 已 经 在 D : 盘 中 解压 了 mongodb 文 件 ， 现 在 让 我 们 创建 一 个 data 的 目录 然后 
在 data 目 录 里 创建 db 目录 。 


:\>mkdir data 


8 6ס6ל\: 


:\data>cd db 


D 
D 
יודה%ח< ה+ה3ר:ם‎ fh 
D 
D 


:\data\dbh> 





你 也 可 以 通过 window 的 资源 管理 器 中 创建 这 些 目录 ， 而 不 一 定 通过 命令 行 。 


命令 行 下 运行 MongoDB 服务 器 


为 了 从 命令 提示 符 下 运行 MongoDB 服 务 器 ， 你 必须 从 MongoDB 目 录 的 bin 目 录 中 执行 
mongod.exe 文 件 。 


חנע 4002<260הסהר: כ 


D:\mongodb\bhin>mongod 
mongod ——help for help and startup options 

hu Jul ₪7 12:59:48 [initandlisten] MongoDB starting : pid=2448 6=27817עסק‎ 3% 
h=/data/db/ 32-hbit 


xx NOTE: when using MongoDB 32 bit, you are limited 60 about 2 gigabytes of data 


ww cee http://blog.mnongodb.org/poct/13779898967/32-—bit—limitatiopns 
ex with ——dur. the limit is lower 


hu Jul ₪87 12:59:48 [initandlisten] db version ,1.8.1ט‎ pdfile version 5 
hu Jul ₪7 12:59:48 [initandlisten] git version: 3429604+53522499664138086+ 6 


hu Jul 97 12:59:48 [initandlisten] build sys info: windows 《5 。 1. 2600. 2. Senh 
vice Pack 3’> BOOST_LIB_UVERSION=1_35 

hu Jul @7? 12:59:49 [initandlisten] waiting for connections on port 27017 

hu Jul @7? 12:59:49 [websvr] wehb admin interface listening on port 28017 





将 MongoDB 服 务 器 作为 Windows 服 务 运 行 


请 注意 ， 你 必须 有 管理 权限 才能 运行 下 面 的 命令 。 执 行 以 下 命令 将 MongoDB 服 务 器 作为 
Windows 服 务 运行 


mongod --bind ip yourlPadress --logpath "Ci:\data\dbConf\mongodb.log" --logappend -- 
dbpath "C:\data\db" הסס--‎ yourPortNumber --serviceName "YourServiceName" -- 
serviceDisplayName "YourServiceName" --install 


下 表 为 mongodb 和 启动 的 参数 说 明 : 


参数 描 ; 


_bind i 绑 定 服务 IP， 若 绑 定 127.0.0.1， 则 只 能 本 机 访问 ， 不 指定 默认 本 
hb 地 所 有 IP 


5 


--logpath 定 MongoDB 日 志文 件 ， 注 意 是 指定 文件 不 是 目录 
--logappend 使 用 追加 的 方式 写 日 志 

--dbpath 指定 数据 库 路 径 

--port 指定 服务 端口 号 ， 黑 认 端 口 27017 
--ServiceName 指定 服务 名 称 


serviceDisplayNam 


--install 指定 作为 一 个 Windows 服 务 安 装 。 


指定 服务 名 称 ， 有 多 个 mongodb 服 务 时 执行 。 


MongoDB 后 台 管 理 Shell 


如 果 你 需要 进入 MongoDB 后 台 管 理 ， 你 需要 先 打 开 mongodb 装 目录 的 下 的 bin 目 录 ， 然 后 执 
行 mongo.exe 文 件 ，MongoDB Shell 是 MongoDB 自 带 的 交互 式 Javascript shell, 用 来 对 
MongoDB 进 行 操作 和 管理 的 交互 式 环境 。 


当 你 进入 mongoDB 后 台 后 ， 它 默认 会 链接 到 test 文档 (数据 库 ) 


D:N\>cd mongodh 


D:Nmongodhb>cd חנ‎ 


D:\mongodb\hin>mongo 
MongoDE shell version: 1.8.1 
connecting to: test 

> 





由 于 它 是 一 个 JavaScript shell， 您 可 以 运行 一 些 简 单 的 算术 运算 : 


D:N\>cdu nongodh 
D:Nmongodhb>cd bin 


D:\mongodb\bhin>mongo 
MongoDbB shell version: 1.8.1 
connecting to: test 

> 2+2 

4 

> 





db 命令 先 了 当前 操作 的 文档 (数据 库 ) 


D:N\>cd mngodb 
D:\mongodb>cd bin 
D:\mongodb\hin>mongo 


MongoDB shell version: 1.8.1 
connecting to: test 





插入 一 些 简 单 的 记录 并 查找 它 : 


D:\"mongodbh\bhin>mongo 

MongoDB shell version: 1.8.1 
connecting to: test 

ככ18:<+>2%ע1798.ע02.מ8 < 


יז ו כו 
id" : 0OhjectIQqc''4el56fdueelaa39phb8ele7ofad'">。 x : 10 >‏ < 
> 





第 一 个 命令 将 10 插 和 人 到 w3r 集 合 的 x 字 段 中 


Linux 平 台 安 丢 MongoDB 


MongoDB 提 供 了 linux 平 台 上 32 位 和 64 位 的 安装 包 ， 你 可 以 在 官网 下 载 安装 包 。 


下 载 地 址 : http://www.mongodb.org/downloads 


05 63201 OSXESDt | 1 ששח 1 | 22-01 שח‎ 64-01 Windows 32-bt Windows Bs-oit Solarsiespe Solaris 55 Source 
rts Ne:s "ote וי‎ 


Production Releass (Racommancac) 


1.82 

0 gowload MA dranload ו‎ 
downlozd doanload dowrlcad doanload downlozd dean 6 

Change oy * 080-867 > 6 2gacr-sle: -0 





Release 5 


一半 上 
安装 


下 载 完 成 后 ， 在 你 安装 的 目录 下 解压 zip 包 。 


创建 数据 库 目 录 


MongoDB 的 数据 存储 在 data 目 录 的 db 目录 下 ， 但 是 这 个 目录 在 安装 过 程 不 会 自动 创建 ， 所 以 
你 需要 手动 创建 data 目 录 ， 并 在 data 目 录 中 创建 db 目录 。 


注意 : 请 将 data 目 录 创 建 于 根 目录 下 (/)。 


File Edit View Terminal Tsbs Help 
debian:/# mkdir data 

debian:/# cd data 

debian:/data# mkdir db 
debian:/data# cd db 
debian:/data/db# [| 


命令 行 中 运行 MongoDB 服务 


你 可 以 再 命令 行 中 执行 nongo 安 装 目录 中 的 bin 目 录 执 行 nongod 命 令 来 启动 ongdb 服 务 。 


debian: /home/ritwik# ./mongodb/binsmongod 
./"ongodbsbin;rongod --help for help and startup options 
Tue Jul 12 07:59:40 [initandlisten] Mongobe starting : pid=3715 port=27917 dbpath=/data/db/ 32-bit 


## NOTE: when using MongobB 32 bit, you are 1171180 to about 2 gigabytes of data 
" 566 http://blog.mongodb. חס‎ 051 / 137788967 /32- 5 
- with --dur, the Lirit 15 lower 


Tug Jul 12 07:59;48 [initandlisten] db version v1.8.2, pdfile version 5 

Tue Jul 12 07:59:48 [initandlisten] git version: 433bbaal4aaba5859dal5bd4deBedf696f55591b 

Tue Jul 12 07;59;48 [initandlisten] build sys info: Linux bs-linux32,19gen.ce 2,6.21.7-2,fcBxen 41 SMP Fri Feb 
5T LIB VERSION=1 37 

Tue Jul 12 07:59:48 [initandlisten] waiting for connections on port 27917 

Tue JUL 12 07:59:48 [websyr] web admin interface listening on port 28617 


MongoDB 后 台 管 理 Shell 


如 果 你 需要 进入 MongoDB 后 台 管 理 ， 你 需要 先 打 开 mongodb 装 目录 的 下 的 bin 目 录 ， 然 后 执 
行 mongo 命 命 文件 。 


MongoDB Shell 是 MongoDB 自 带 的 交互 式 Javascript shell, 用 来 对 MongoDB 进 行 操 作 和 管理 
的 交互 式 环境 。 


当 你 进入 mongoDB 后 台 后 ， 它 默认 会 链接 到 test 文档 (数据 库 ) 


debian: /home/ritwik# .Amongodbybinymongod 
./"ongodbsbin;rongod --help for help and startup options 
Tye Jul 12 07:59:48 [initandlisten] WongoDB starting : pid=3715 port=27917 dbpath=/data/db/ 32-bit 


## NOTE: when using NongobB 32 bit, you are 1171160 to about 2 gigabytes of data 
本 see http://blog.mongodb.org/:post/137788967/32-bit- limitations 
₪ with --dur, the Lirit is lower 


Tug Jul 12 07:59;48 [initandlisten] db version v1.8.2, pdfile version 5 

Tue Jul 12 07:59:48 [initandlisten] git version: 433bbaal4aabase60dalsbd4deBedf680f56501b 

Tue Jul 12 07:59;48 [initandlisten] build sys info: Linux bs-linux32.19gen.ce 2,6.21.7-2,fcBxen 41 SMP Fri Feb 
זפ‎ LIB VERSION=1 ]7 

Tue Jul 12 07:59:48 [initandlisten] waiting for connections on port 27917 

Tye JUL 12 07:59;48 [websyr] web admin interface listening on port 28617 


由 于 它 是 一 个 JavaScript shell， 您 可 以 运行 一 些 简 单 的 算术 运算 : 


W3School MongoDB 教程 


File Edt View JTJerminal Tabs Help 
debian:/home/ritwik# ./mongodb/bin/mongo 
MongoDB shell version: 1.8.2 

connecting to: test 

> 3+5 

8 

> db 

7% 

> 


现在 让 我 们 插入 一 些 简 单 的 数据 ， 并 对 插入 的 数据 进行 检索 : 


debian:/home/ritwik# ./mongodb/bin/mongo 
MongoDB shell version: 1.8.2 

connecting to: test 

> 3+5 

8 

> db 

test 

> db.w3r.insert({z:8}) 

> dh.w3r.find() 

+ " 10" : 00[66+16)"461005266073+60026+72818"(, "2" : 8] 
> 


第 一 个 命令 是 将 数据 8 插入 到 w3r 集 合 〈 表 ) 的 z 字段 中 。 


MongoDb web 用 户 界面 


在 比 MongoDB 服 务 的 端口 多 1000 的 端口 上 ， 你 可 以 访问 到 MondoDB 的 web 用 户 界 面 。 


如 : 如 果 你 的 MongoDB 运 行 端口 使 用 默认 的 27017， 你 可 以 在 端口 号 为 28017 访 问 web 用 户 界 
面 。 


Linux 平 台 安 装 MongoDB 21 
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MongoDB 数据 库 ， 对象 ， 集 合 


摘 述 


人 中 的 基础 概念 ， 在 mongodb 中 基本 的 概念 是 文档 、 集 
、 数 据 库 ， 下 面 我 们 挨个 介绍 


效 据 库 


一 个 mongodb 中 可 以 建立 多 个 数据 库 。 

MongoDB 的 默认 数据 库 为 "db"， 该 数据 库存 储 在 data 目 录 中 。 

在 MongoDB 中 可 以 创建 数据 库 ， 如 果 你 想 使 用 MongoDB， 创 建 数据 库 不 是 必要 的 。 
"show dbs" 命令 可 以 显示 所 有 数据 的 列表 。 


D:Nmongodphb、\phbin>mongo 
MongoDB 52611 version: 
connecting to: test 
show dbs 
1 > 62% 2ע‎ 

: ה כ 

empt vy> 
student 0@.03125GB 
test @.903125GB 


ID:\mongodb\bin>nmongo 


MongoDB shell version: 
1 : test 





> use student 
switched to db student 
> 





以 上 实例 命令 中 ，"student" 是 你 要 检索 的 数据 库 。 

在 下 一 个 章节 我 们 将 详细 讲解 MongoDB 中 命令 的 使 用 。 

数据 库 名 称 可 以 是 任何 字符 ， 但 是 不 能 包含 空 字符 串 ， 点 号 (.) ， 或 者 " "。 
"system" 作为 系统 保留 字符 串 不 能 作为 数据 库 名 。 


数据 库 名 不 能 包含 "$"。 


文档 
文档 是 mongodb 中 的 最 核心 的 概念 ， 是 其 核心 单元 ， 我 们 可 以 将 文档 类 上 比 成 关系 型 数据 库 中 
的 每 一 行 数据 。 


多 个 键 及 其 关联 的 值 有 序 的 放置 在 一 起 就 是 文档 。 在 mongodb 中 使 用 一 种 类 json 的 bson 存 储 
数据 。 


bson 数 据 可 以 理解 为 在 json 的 基础 上 添加 了 一 些 json 中 没有 的 数据 类 型 。 
如 果 我 们 会 json， 那 么 bson 我 们 就 已 经 掌握 了 一 半 了 ， 至 于 新 添加 的 数据 类 型 后 面 我 会 介 


绍 。 


文档 例子 如 下 : 


+ site : "w3cschool.cc" } 


通常 ，"object (对 象 )" 术语 是 指 一 个 文件 。 
文件 类 似 于 一 个 RDBMS 的 记录 。 
我 们 可 以 对 集合 (collection) 进行 插入 ， 更 新 和 删除 操作 。 


下 表 将 帮助 您 更 容易 理解 Mongo 中 的 一 些 概念 : 


RDBMS MongoDB 
Table ( 表 ) Collection (集合 ) 
Column ( 栏 ) Key ( 键 ) 
Value )18( Value ))8( 
Records / Rows (记录 / 列 ) Document / Object (文档 /对 象 ) 


下 表 为 MongoDB 中 常用 的 几 种 数据 类 型 。 


数据 类 型 描述 


可 以 是 一 个 空 字符 串 或 者 字符 组 合 。‏ אוו 


integer ( 整 型 ) 整数 。 


广 > 
boolean (布尔 逻辑 值 True 或 者 False。 


型 ) 
double 双 精 度 浮 点 型 
null 不 是 0， 也 不 是 空 。 
array 数组 : 一 系列 值 

对 象 型， 程序 中 被 使 用 的 实体 。 可 以 是 一 个 值 ， 交 量 ， 辑 数 ， 或 者 数 
8 据 结构 。 

timestamp 存 储 为 64 为 的 值 ， 只 运行 一 个 mongod 时 可 以 确保 是 唯一 

timestamp 的 。 前 32 位 保存 的 是 UTC 时 间 ， 单 位 是 秒 ， 后 32 为 是 在 这 一 秒 内 的 


计数 值 ， 从 0 开始 ， 每 新 建 一 个 MongoTimestamp 对 象 就 加 一 。 


Internationalized UTF-8 字符 串 。 

Strings 

在 mongodb 中 的 文档 需要 使 用 唯一 的 关键 字 id 来 标识 他 们 。 几 乎 每 
一 个 mongodb 文 档 都 使 用 _id 字 段 作 为 第 一 个 属性 (在 系统 集合 和 定 
容量 集合 (capped collection) 中 有 一 些 例外 ) 。_id 值 可 以 是 任何 类 
型 ， 最 常见 的 做 法 是 使 用 Objectld 类 型 。 


Object 5 


集合 


集合 就 是 一 组 文档 的 组 合 。 如 果 将 文档 类 上 比 成 数据 库 中 的 行 ， 那 么 集合 就 可 以 类 上 比 成 数据 库 
的 表 。 


在 mongodb 中 的 集合 是 无 模式 的 ， 也 就 是 说 集合 中 存储 的 文档 的 结构 可 以 是 不 同 的 ， 比 如 下 
面 的 两 个 文档 可 以 同时 存 人 到 一 个 集合 中 : 


{"name":"mengxiangyue"} {"Name":"mengxiangyue","sex":"nan"} 


当 第 一 个 文档 插入 时 ， 集 合 就 会 被 创建 。 


合法 的 集合 名 

集合 名 称 必须 以 字母 或 下 划 线 开头 。 
集合 名 可 以 保护 数字 

集合 名 称 不 能 使 美元 符 "$"，"$" 是 系统 保留 字符 。 


集合 的 名 字 最 大 不 能 超过 128 个 字符 。 


另外 ，"." 号 的 使 用 在 集合 当中 是 允许 的 ， 它 们 被 成 为 子 集 合 (Subcollection) ; 比如 你 有 一 个 
blog 集 合 ， 你 可 以 使 用 blog.title，blog.content 或 者 blog.author 来 帮 组 你 更 好 地 组 织 集合 。 


如 下 实例 : 


db. tutorials.php.findone() 


capped collections 


Capped collections 就 是 固定 大 小 的 collection。 
它 有 很 高 的 性 能 以 及 队列 过 期 的 特性 (过 期 按照 插入 的 顺序 ). 有 点 和 "RRD" 概念 类 似 。 


Capped collections 是 高 性 能 自动 的 维护 对 象 的 插入 顺序 。 它 非常 适合 类 似 记 录 日 志 的 功能 和 
标准 的 collection 不 同 ， 你 必须 要 显 式 的 创建 一 个 capped collection， 指定 一 个 collection 的 大 
小 ， 单 位 是 字 节 。collection 的 数据 存储 空间 值 提 前 分 配 的 。 


要 注意 的 是 指定 的 存储 大 小 包含 了 数据 库 的 头 信息 。> db.createCollection("mycoll", 
{capped:true, ([26:100000ו5‎ 


。 在 capped collection 中 ， 你 能 添加 新 的 对 象 。 

。 能 进行 更 新 ， 然 而 ， 对 象 不 会 增加 存储 空间 。 如 果 增 加 ， 更 新 就 会 失败 。 
。 数据 库 不 允许 进行 删除 。 使 用 drop() 方 法 删除 collection 所 有 的 行 。 

。 注意 : 删除 之 后 ， 你 必须 显 式 的 重新 创建 这 个 collection。 

。 在 32bit 机 器 中 ，capped collection 最 大 存储 为 1e9( 1X109) 个 字 节 。 


元 数据 
数据 库 的 信息 是 存储 在 集合 中 。 它 们 使 用 了 系统 的 命名 空间 : 
dbname.system.* 


在 MongoDB 数 据 库 中 名 字 空 间 <dbname>.system.* 是 包含 多 种 系统 信息 的 特殊 集合 
(Collection)， 如 下 : 


集合 命名 空间 描述 


dbname.system.namespaces 列 出 所 有 名 字 空 间 。 

dbname.system.indexes 列 出 所 有 索引 。 

dbname.system.profile 包含 数据 库 概 要 (profile) 信 息 。 
dbname.system.users 列 出 所 有 可 访问 数据 库 的 用 户 。 
dbname.local.sources 包含 复制 对 端 (slave) 的 服务 器 信息 和 状态 。 


对 于 修改 系统 集合 中 的 对 象 有 如 下 限制 。 


在 插入 数据 ， 可 以 创建 索引 。 但 除 此 之 外 该 表 信息 是 不 可 变 的 (特殊 的 drop index 命 令 将 自动 
更 新 相关 信息 )。 


是 可 修改 的 。 是 可 删除 的 。 


MongoDB - 连接 


摘 述 


在 本 教程 我 们 将 讨论 MongoDB 的 不 同 连接 方式 。 


启动 MongoDB 服 务 


在 前 面 的 教程 中 ， 我 们 已 经 讨论 了 如 何 启 动 MongoDB 服 务 ， 你 只 需要 在 MongoDB 安 装 目 录 的 
bin 目 录 - 


执行 启动 操作 后 ，mongodb 在 输出 一 些 必 要 信息 后 不 会 输出 任何 信息 ， 之 后 就 等 待 连接 的 建 
立 ， 当 连接 被 建立 后 ， 就 会 开始 打印 日 志 信 息 。 


你 可 以 使 用 MongoDB shell 来 连接 MongoDB 服务 器 。 你 也 可 以 使 用 PHP 来 连接 mongodb。 
本 教程 我 们 会 使 用 MongoDB shell 来 连接 Mongodb 服 务 ， 之 后 的 章节 我 们 将 会 介绍 如 何 通 过 
php 来 连接 MongoDB 服 务 。 


默认 情况 下 ，MongoDB 的 启动 端口 为 27017。 比 MongoDB 和 启动 端口 大 1000 的 端口 为 
MongoDB 的 web 用 户 界 面 ， 你 可 以 再 浏览 器 中 输入 http:Wlocalhost:28017 来 访问 MongoDB 的 
web 用 户 界 面 。 


通过 shell 连 接 MongoDB 服 务 


你 可 以 通过 执行 以 下 命令 来 连接 MongoDB 的 服务 。 


主意 : localhost 为 主机 名 ， 这 个 选项 是 必须 的 : 
mongodb://localhost 


当 你 执行 以 上 命令 时 ， 你 可 以 看 到 以 下 输出 结果 : 


D:\"mongodb\bhin>mongo 
MongoDB shell version: 


connecting to: test 
> mongodbh://localhost 





如 果 你 检查 从 哪里 连接 到 MongoDB 的 服务 器 ， 您 可 以 看 到 如 下 信息 


:Nmongodb\hbin>nongod 

ongod ——help for help and startup options 

Jed Jul 13 14:14:51 [initandlisten] MongoDB starting : pid=2820 port=27017? dbpat 
"=Adata/db/ 32—hit 


NOTE: when using MongoDB 32 bit, you are linited to about 2 gigabytes of data 


בי בי 1 תי רכ המייק i‏ ביני יד See httpb:“hblog-mongodhb‏ 
the 11016 15 lower‏ ,ע800-- with‏ 


Jed Jul 13 14:14:51 [initandlisten] db version vi.8.1. pdfile version 4.5 

Jed Jul 13 14:14:51 [initandlisten] git version: a429cd4f535hb2499cc4130hb@6ff7?7c26 
41:84 

Jed Jul 13 14:14:51 [initandlisten] build sys info: uindows 《5 。 1, 2600, 2, ש6פ'‎ 
ice Pack 3’> BOOST_LIB_VERSION=1_35 

Jedu Jul 13 14:14:51 [initandlisten] waiting for connections on 6>6עסע‎ 7 

[wehbhsoukr] weh admin intekface 1istenina on 1 2 28917‏ 14:14:51 13 וח תו ידו 
[IT‏ 





最 后 一 行 ( 标 记 处 ) ， 打 印 了 你 成 功 连接 上 MongoDB 服 务 的 信息 。 


MongoDB 连 接 命 合格 式 
使 用 用 户 名 和 密码 连接 到 MongoDB 服 务 器 ， 你 必须 使 用 
username:password@hostname/dbname' 格式 ，'Username' 为 用 户 名 ，'password' 为 密码 。 


使 用 用 户 名 和 密码 连接 登陆 到 默认 数据 库 : 


mongodb://mongo_admin:AxB6 _w3r@localhost/ 


以 上 命令 中 ， 用 户 mongo_admin 使 用 密码 AxB6_w3r 连 接 到 本 地 的 MongoDB 服 务 上 。 输 出 结 
果 如 下 所 示 : 


D:\"mongodb\bin>mongo 
MongoDB shell version: 1.8.1 
connecting to: test 


> mongodbh://mongo_admin :fxB6_w3r@localhost/ 





使 用 用 户 名 和 密码 连接 登陆 到 指定 数据 库 : 
连接 到 指定 数据 库 的 格式 如 下 : 


mongodb://mongo_admin:AxB6 _w3r@localhost/w3r 


连接 实例 


连接 本 地 数据 库 服务 器 ， 端 口 是 默 认 的 。 


mongodb : 


使 用 用 户 名 fred， 密 码 foobar 登 录 localhost 的 admin 数 据 库 。 


mongodb://fred:foobar@localhost 


使 用 用 户 名 fred， 密 码 foobar 登 录 localhost 的 baz 数 据 库 。 


mongodb://fred:foobar@localhost/baz 


连接 replica pair, 服务 器 1 为 example1.com 服 务 器 2 为 example2。 


mongodb://example1.com:27017,example2.com:27017 


连接 replica set 三 台 服 务 器 (端口 27017, 27018, 和 27019): 


mongodb://localhost, localhost:27018, localhost:27019 


连接 replica set 三 台 服 务 器 , 写 人 操作 应 用 在 主 服务 器 并 且 分 布 查询 到 从 服务 器 。 


mongodb://host1, host2,host3/?slaveOk=true 


直接 连接 第 一 个 服务 器 ， 无 论 是 replica set 一 部 分 或 者 主 服务 器 或 者 从 服务 器 。 


mongodb://host1, host2,host3/?connect=direct;slaveOk=true 


当 你 的 连接 服务 器 有 优先 级 ， 还 需要 列 出 所 有 服务 器 ， 你 可 以 使 用 上 述 连接 方式 。 


安全 模式 连接 到 localhost: 


mongodb://localhost/?safe=true 


以 安全 模式 连接 到 replica set， 并 且 等 待 至 少 两 个 复制 服务 器 成 功 写 入 ， 超 时 时 间 设 置 为 2 
秒 。 


mongodb://host1, host2, host3/?safe=true;w=2;wtimeoutMS=2000 


参数 选项 说 明 
标准 格式 : 


mongodb://[username:password@|]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[databas 


ו |“ 











标准 的 连接 格式 包含 了 多 个 选项 (options)， 如 下 所 示 : 


选项 


replicaSet=name 


slaveOk=truel|false 


safe=true|ffalse 


ח-/\ 


wtimeoutMS=ms 


fsync=truel|ffalse 


journal=truel|ffalse 


connectTimeoutMS=ms 


socketTimeoutMS=ms 


描述 
验证 replica set 的 名 称 。 Impliesconnect=replicaSet. 
ו‎ 驱动 会 连接 第 一 台 机 器 ， 即 使 
台 服 务 器 不 是 主 。 在 connect=replicaSet 模 式 下 ， 了 驱动 会 发 
8 作 分 布 在 其 他 从 服务 器 。 
false: 在 connect=direct 模 式 下 ， 驱 动 会 自动 找寻 主 服务 器 . 


在 connect=replicaSet 模式 下 ， 驱 动 仅 仅 连接 主 服务 器 ， 并 且 
所 有 的 读 写 命令 都 连接 到 主 服务 器 。 


true: 在 执行 更 新 操作 之 后 ， 驱 动 都 会 发 送 getLastError 命 令 来 
确保 更 新 成 功 。( 还 要 参考 wtimeoutMS). false: 在 每 次 更 新 之 
后 ， 驱 动 不 会 发 送 getLastError 来 确保 更 新 成 功 。 


驱动 添加 {w : ח‎ ( 到 getLastError 命 令 . 应 用 于 safe=true。 


驱动 添加 { wtimeout : ms } 到 getlasterror 命令 . 应 用 于 
safe=true. 


true: 驱动 添加 + fsync : true } 到 getlasterror 命令 .应 用 于 
safe=true. false: 驱动 不 会 添加 到 getLastError 命 דייל‎ 


如 果 设 置 wie true, 同步 到 journal (在 提交 到 数据 库 前 写 入 到 实 
体 中 ). 应 用 于 safe=true 


可 以 打开 连接 的 时 间 。 
发 送 和 接受 sockets 的 时 间 。 


PHP 安 装 MongoDB 扩 展 驱 动 


摘 述 


本 教程 怪 向 大 家 介绍 如 何在 Linux、window、Mac 平 台 上 安装 MongoDB 扩 展 。 


Linux 上 安装 MongoDB PHP 扩 展 


在 终端 上 安装 
你 可 以 在 linux 中 执行 以 下 命令 来 安装 MongoDB 的 PHP 扩展 驱动 


$ 5000 pecl install mongo 


使 用 php 的 pecl 安 装 命令 必须 保证 网 络 连接 可 用 以 及 root 权 限 。 
安装 手册 


如 果 你 想 通 过 源码 来 编译 扩展 驱动 。 你 必须 手动 编译 源码 包 ， 这 样 做 的 好 是 最 新 修正 的 bug 包 
含 在 源码 包 中 。 


你 可 以 在 Github 上 下 载 MongoDB PHP 了 驱动 包 。 访 问 github 网 站 然后 搜索 "mongo php driver" 
(下 载 地 址 : https://github.com/mongodb/mongo-php-driver)， 下 载 该 源码 包 ， 然 后 执行 以 下 


公公 . 
0 כ‎ : 


$ tar zxvf mongodb-mongodb-php-driver-<commit_id>.tar.gz 
$ cd mongodb-mongodb-php-driver-<commit_id> 

$ phpize 

% ./configure 

$ sudo make install 


如 果 你 的 php 是 自己 编译 的 ， 则 安装 方法 如 下 (假设 是 编译 在 /usr/local/php 目 录 中 ) : 


$ tar zxvf mongodb-mongodb-php-driver-<commit_id>.tar.gz 

$ cd mongodb-mongodb-php-driver-<commit_id> 

$ /usr/local/php/bin/phpize 

$ ./configure --with-php-config=/usr/local/php/bin/php-config 
$ sudo make install 


执行 以 上 命令 后 ， 你 需要 修改 php.ini 文 件 ， 在 php.ini 文 件 中 添加 mongo 配 置 ， 配 置 如 下 : 


extension=mongo .so 


/3School MongoDB : 
注意 : 你 需要 指明 extension_dir 配置 项 的 路 径 。 


window 上 安装 MongoDB PHP 扩 展 


Github 上 已 经 提供 了 用 于 window 平 台 的 预 编 译 php mongodb 驱 动 二 进 制 包 (下 载 地 址 : 
https://s3.amazonaws.com/drivers.mongodb.org/php/index.html)， 你 可 以 下 载 与 你 php 对 应 
的 版 本 ， 但 是 你 需要 注意 以 下 几 点 问题 : 


。 VC6 是 运行 于 Apache 服务 器 

* 'Thread safe' (线程 安全 ) 是 运行 在 Apache 上 以 模块 的 PHP 上 ， 如 果 你 以 CGI 的 模式 运行 
PHP， 请 选择 非 线程 安全 模式 (' non-thread safe') 。 

e VC9 是 运行 于 IIS 服务 器 上 。 

* 下 载 完 你 需要 的 二 进 制 包 后 ， 解 压 压 缩 包 ， 将 'php_mongo.dll 文 件 添 加 到 你 的 PHP 扩 展 
目录 中 (ext) 。ext 目 录 通 常 在 PHP 安 装 目录 下 的 ext 目 录 。 


打开 php 配 置 文件 php.ini 添加 以 下 配置 : 
extension=php_mongo ,d]1 
重启 服务 器 。 
通过 浏览 器 访问 phpinfo， 如 果 安 装 成 功 ， 就 会 看 到 类 型 以 下 的 信息 : 


mongo 


mongo.allow_empty_keys 





你 可 以 使 用 'autoconf' 安 装 MongoDB PHP 扩 展 驱 动 。 
你 可 以 使 用 'Xcode' 安 装 MongoDB PHP 扩 展 驱 动 。 


如 果 你 使 用 XAMPP， 你 可 以 使 用 以 下 命令 安装 MongoDB PHP 扩 展 驱 动 : 


5000 /Applications/XAMPP/xamppfiles/bin/pecl install mongo 


如 果 以 上 命令 在 XMPP 或 者 MAMP 中 不 起 作用 ， 你 需要 在 Github 上 下 载 兼 容 的 预 编译 包 。 


然后 添加 'extension=mongo.so' 配 置 到 你 的 php.ini 文 件 中 。 


MongoDB 数据 插入 


摘 述 

本 章节 中 我 们 将 向 大 家 介绍 如 何 将 数据 插入 到 MongoDB 的 集合 中 。 
文档 的 数据 结构 和 JSON 基 本 一 样 。 

所 有 存储 在 集合 中 的 数据 都 是 BSON 格 式 。 


BSON 是 一 种 类 json 的 一 种 二 进 制 形 式 的 存储 格式 ,简称 Binary JSON 


MongoDB 数 据 库 切换 
以 下 命令 可 以 使 用 "myinfo" 数 据 库 : 
use myinfo Switch to db myinfo 


> ₪56 muyinfop 





switched to db myinfo 
> 


为 MongoDB 效 据 库 定 义 一 个 文档 


以 下 文档 可 以 存储 在 MongoDB 中 : 


document=({ "user 10" : "ABCDBWN","password" :"ABCDBWN" ,"date of_join" : 
"15/10/2010" , "education™" :"B.C.A." , "profession" : "DEVELOPER","interest" : 
"MUSIC", "community_name" :["MODERN MUSIC", "CLASSICAL 

MUSIC", "WESTERN MUSIC"],"community_moder_id™" : ["MR. BBB", "MR. JJJ","MR 
MMM"],"community_members" : [500,200,1500],"friends_ 10" : 

["MMM4123", "NNN123", "000123"], "ban_friends_id" : 

["BAN123", "BAN456", "BAN789"]}); 


命令 执行 如 下 图 所 示 : 


: "הבסך +0 66א08", "א2622%%ה": "6תסש5פ5ק","א622תה" : "10 <0₪56"+>=>ה6הטססה > 
: כ וני ו 
commun it‏ יו ו ו וו כ כ ו 


MMM”],."community_members : ₪ ,8‏ ת'' ,"שק .תא","עתם .הא"] : "108 <ש6אסת על 
:["BAN123",."BAN45‏ "10 85ה216+ ההכ",["122".9"000123אאא", "123" : "10 85ה6בע+",ן 
ו ו ו 





显示 已 定义 的 文档 


已 定义 的 文档 显示 格式 如 下 所 示 : 


"usekh_id"”: "ABCDBWN", 
"Dassword' : "ABCDBWN". 
“date_of_ Td 
WT : 8" 
"וש1טטט+טעע"‎ : "DEVELOPER'". 
"interest"” : "MUSIC",. 
"community_name” : ] 
"MODERN 10516". 
"CLASSICAL MUSIG". 
"WESTERN 0516" 
1. 
"communituw_ ₪006: 14" : ] 
"MR. BBB". 
.תו"‎ 0". 
"MR MMM"’ 
1. 
"community_membhers'” : [ 
568 . 
288 . 
18 
1. 
"friends_id' : [ 
Wi 23 '' . 
ונאאא'י‎ 23 '' . 
"0001237 
1. 
יו ו‎ 
1א חת'י‎ 23 '' , 
"BAN456", 
"BAN?89" 





在 集合 中 插入 文档 
将 以 上 的 文档 数据 存储 到 "myinfo" 数据 库 中 的 "userdetails" 集合 ， 执 行 如 下 命令 : 


db.userdetails.insert(document) 


> 
> dh.userdetails.insertdocument>; 


> 


使 用 换行 符 插入 数据 


当 文 档 的 数据 较 多 的 时 候 ， 我 们 可 以 使 用 换行 符 来 分 割 文 档 数据 ， 如 下 所 示 : 





document=({"user_ 10" : "ABCDBWN","password" :"ABCDBWN" ,"date of_join" : "15/10/2010" , 
"education™" :"B.C.A." , "profession" : "DEVELOPER","interest" : "0516", 
"community_name" :["MODERN MUSIC", "CLASSICAL MUSIC", "WESTERN MUSIC"], 
"community_moder_id™" : ["MR. BBB", "MR. JJJ", "MR MMM"], 

"community_members" : [500,200,1500],"friends_id™" : ["MMM123", "NNN123","000123"], 


"ban_friends_id" :["BAN123", "BAN456", "BAN789"]}); 
了 及" 


命令 执行 如 下 图 所 示 : 


> quocument=c< usekr id” : "ABCDBWN",. "password' :"ABCDBWNH ."date_of_join” : "i5/1 
0/2018" . 
"education” :"B.G.A." . "profession : "DEUELOPER",""interest" : MUSIC” 
"community_name'’ : ["MODERN MUSIC"。 "CLASSICAL MUSIC",. "WESTERN MUSIC7"] 。 
community _moder 18" : .תא"]‎ BBB",. "MR. JJJ".""MR MMN"]. 
"community_members'” : 85ה16ע2+",[58,208,1588]‎ 10" : ["MMM123", 1אאא''‎ 23 1 





"hban_friends_id" :["BAN123","BAN456", "BRN789"]》>>; 


集合 中 直接 插入 数据 〈 无 定义 文档 ) 


数据 可 以 不 用 定义 文档 通过 shell 直 接 插入 : 


db.userdetails.insert({"user_id" : "xyz123","password" "2123ץא":‎ ,"date 0% "הבסך‎ : 8 
"education™ :"M.C.A." , "profession" : "Software "56765%ה6","1ה50158ה600‎ : "110", 
"community" : ] 

{ 

"name" : "DDD FILM CLUB", 
"moder_id" : .אא"‎ DBNA", 
"members" : "25000" , 

}, 

{ 

"name" : "AXN MOVIES", 
"moder 10" : "DOGLUS HUNT", 
"members" : "15000", 

}, 

{ 

"name" : "UROPEAN FILM LOVERS", 
"moder_id" : "AMANT LUIS", 
"members" : "20000", 

} 

1, 

"friends” :] 

{ 

"user_id" : "KKK258", 

1, 

{ 

Ie‏ 0: "10 "6פט" 

}, 

{ 

"user_id" : "MMM369", 

} 

1, 

"ban_friends" :] 

{ 

"user_id" : "BAN147" 

}, 

{ 

"user_id" : "BAN258" 

}, 

{ 

"user_id" : "BAN369" 

} 

] 

}); 


图 





命令 执行 如 下 图 所 示 : 


> 


> dh.userdetails.insert"user_id" : 


4 . 


Wi pd /281₪" ， 
"education” : "N.C.A." 


"community' : [ 


mname'’ - 
"modekrk_id"” : 
members : 
2. 

< 
name 
"modek_id"” : 
members : 
5 

< 
name'’ 
"moder_id'” : 
members : 
> 

1. 

ור יזור ל ו 


"25000"". 


15888" , 


"AMANT 
"28000". 


יב 


5 


"KEK258"", 


מו יו ו כ 


י. 


sw‏ ו 


"LLL147", 


: יד ו כ 


* 


> 
+ 


"MNM369"", 


USek_iq”" : 


km 


han_friends" :] 


= 


0 


"BAN14?"‏ : ו 


4 


sm 


user_id' : "BAN258" 


4 


zm 


user_id” : "BAN369" 


WW bd 
4 
Cp 


db.userdetails.find(); 


."5 ₪001 אא" : 
."זאו "DOGLUS‏ 


* 


profession : 


"DDD FILM 608". 
"NR. DBNA". 


: "UROPEAN FILM LOUERS”。 
LUIS". 


"xyz123"."password " "2123טשא":‎ ."date_of_joi 


"Softwake consultant'’,''interest'” : “了 





וי כ וו ו כ 

"xyz2123",‏ : "העסשפפה" 

"duate_of_ join"”: ונ‎ 

eduucation' : "8.606 0 

"rofession : "Software consultant"’. 

."7110" : "66265%6חב" 

"community'” : [ 

+ 

"mame : "DDD FILM CLUB". 
"moder_id' : "MR. DBNA". 
כ‎ "250008” 


"name” : אאחה"‎ MOUILES"'. 
moder_id” : "DOGLUS HUNT™, 
"5ע6כה6ה"‎ : "158088" 


"mame : "UROPEAN או‎ 
moder_id” : "AMANT LUIS", 
כ ו‎ "20000” 
> 
1 


2 
ור וזו ב ל ו 


"KKK258"‏ : "106 56ו" 
'יל4 1.ז.ז.זיי יו כ 
"MMM369"‏ ידו כ 
15 
"han_friends : [‏ 
'"47 1א חת'י "10 56" 


"BAN258"‏ ויו כו 


"user_id : "BAN369" 





() 30 וט ב 5 כ סט הס 


摘 述 
本 章节 我 们 将 开始 学 习 如 何 更 新 MongoDB 中 的 集合 数据 。 
MongoDB 数 据 更 新 可 以 使 用 update() 范 数 。 


db.collection.update( criteria, objNew, upsert, multi ) 


update() 范 数 接受 以 下 四 个 参数 : 


* criteria : update 的 查询 条 件 ， 类 似 sql update 查 询 内 where 后 面 的 。 

* objNew : update 的 对 象 和 一 些 更 新 的 操作 符 (如 $,$inc...) 等 ， 也 可 以 理解 为 sql update 
查询 内 set 后 面 的 

* upsert : 这 个 参数 的 意思 是 ， 如 果 不 存在 update 的 记录 ， 是 否 插入 objNew,true 为 插入 ， 
默认 是 false， 不 插入 。 

* multi : mongodb 默 认 是 false, 只 更 新 找到 的 第 一 条 记录 ， 如 果 这 个 参数 为 true, 就 把 按 条 件 
查 出 来 多 条 记录 全 部 更 新 。 


在 本 教程 中 我 们 使 用 的 数据 库 名 称 为 "myinfo"， 集 合 名 称 为 "userdetails"， 以 下 为 插入 的 数 
据 : 


> document=({ 人 "user 10" : "MNOPBWN","password" :"MNOPBWN" , "date of_join" : "1/2010" 

,;"education" :"M.C.A." , "profession" : "CONSULTANT","interest" : "MUSIC","community_name 
"CLASSICAL MUSIC", "WESTERN MUSIC"],"community_moder_id" : ["MR. BBB™, "MR. JJJ", "MR MMM"], 
[500, 200, 1500], "friends_id" : ["MMM123", 05ה16ז+ ההס",["123","000123אאא"‎ 10" :["BAN123","B 


加 





> db.userdetails.insert(document) 


> document=({"user_id" : "QRSTBWN","password" :"QRSTBWN" ,"08856 0+ "הבסך‎ : "17/10/2010" , 
, "ה0ב655זסזס"‎ : "MARKETING","interest" : "MUSIC","community_name" :["MODERN ₪516", "CLA 
MUSIC"], "community_ moder 10" : .הא"]‎ BBB", "MR. JJJ", "MR MMM"],"community_members" : [500, 
["MMM123", "NNN123", "000123"], "ban_friends_id" :["BAN123", "BAN456", "BAN789"]}); 


ES 





> db.userdetails.insert(document) 


update() 命 兮 


如 果 我 们 想 将 "userdetails" 集 合 中 "user_ id" 为 "QRSTBWN" 的 "password" 字 段 修改 
为 "NEWPASSWORD'"， 那 么 我 们 可 以 使 用 update() 命 令 来 实现 〈 如 下 实例 所 示 ) 。 


如 果 criteria 参 数 匹 配 集合 中 的 任何 一 条 数据 ， 它 将 会 执行 蔡 换 命 合 ， 否 则 会 插入 一 条 新 的 数 
据 。 


以 下 实例 将 更 新 第 一 条 匹配 条 件 的 数据 : 


> db.userdetails.update({"user_id" : "QRSTBWN"}, {"user_id" : "QRSTBWN", "password" :"NEWPA 
,"date_of_join" : "17/10/2010" , "education" :"M.B.A." , "profession™" : "MARKETING","inter 
"MUSIC", "community_name" :["MODERN MUSIC", "CLASSICAL MUSIC", "WESTERN MUSIC"],"community_ 
.הא","פפם‎ JJJ", "MR MMM"],"community_members" : [500,200,1500],"friends_id" : ["MMM123","N 


DE YY 


> 
> Dh.userdetails.update"user_id' : "QRSTBIN'Y? .user_id : ‘QRSTBUWN'. "password 
" 2"NEWPASSWORD' 。"qate_of_join”: "17?/10/2010" ."education'” :"M.H.A.' , "profes 
ion'” : "MARKETING'',''interest"” :; "MUSIG, "community_nane'’ :["MODERN MUS]GC'’,. ‘GLA 
SSICAL MUSIC",. WESTERN MUSIC ] "CunmuilLy mucrr iu 2 ["MR. BBB,. MR. Jd."MR M 
M"'],."conmunity_ members'” : הלבו הר יו דיל של כ רוס ץקל רכ‎ [MMM123", "NNN123". "000 
123"],."han_friends_iq' :["BAN123"''.""BAN456"."BAN?49"]?>; 








查看 集合 中 更 新 后 的 数据 
我 们 可 以 使 用 以 下 命令 查看 数据 是 否 更 新 : 


> db.userdetails.find(); 


גידו כ > _id"” : 0hbjectIQ 4e26ca5cf5sd4de3hbzy76b638e4dubfb‏ 
0 ,".6.0./" : "ה68068%10" ,"16/18/2018" : "ה01ך +0 88%6" "MNOPBWN”.‏ : 
ורי ו כ ו מו בב כו CONSULTANT',.‏ 
"UVESTERN MUSIG™ 13, 7‏ ורי כ LASSICAL‏ 
J]. "conmunity_members' : ] 588. 288, 1588 ]- "friends_id'” : ]‏ "חחח תו" ." 
"פפלאהת" ,"456אהת" ,"123אהת" ] : "18 85ה16ע+ ההמ" ,[ "000123" ,"123אאא'י" ."3 
id : “9ORSTBWN“ 。 “passwohd‏ כ הור :ב גי ו כ ו רד גיל ”1Q"”: OhjectIQt‏ 


.''. 8.2.8" : "68068610" ,"17/18/2818" : "הבס +0 8866" ,"פת0ש55הקשתאיי 
"community_name'” : [ "MODERN MUSIG".‏ רוכ בו בב כ ירי וו ה ו 
ינויו MUSIC"”]。‏ ונ וריו כו “CeLhSSICRL‏ 
אא" ] : "106 05ה6ב1ע?" ,[ 1588 ,208 .588 ] : "פע6כחס6ה עְ16הטההסם" ,ך "חחח תח" ."זז 
"BAN?89'" ]‏ ,"456אהת" ,"123אהת" ] : "18 05ה16ע+ חהּמ" ,[ "000123" ,"123אאאיי* ,"123 





更 多 实例 
只 更 新 第 一 条 记录 : 


db.testOo.update( + count :LS$ot : 1 7 [7 , + 9565 1: + "56552" : ז["א0"‎ 7 (; 


全 部 更 新 : 














db .testo.update( הסהטסס"‎ 2 0906 3 7 ESet ETEeskc2 OK rialse 0006 (0 
4 | 
只 添加 第 一 条 : 

db .testo.update( "6הטסס"‎ : + 890% : 4 7 7 , + 6565 : + "56555" Oo 6,18156ט"1,5‎ (; 
1 ה‎ 
全 部 添加 加 进去 : 

db .testo.update( scounmt : + 805 : 5 7 7 , + 8565 1: + "56585" OK 7,5706,%706 (; 
全 部 更 新 : 

db .testo.update( GoOunt : + 805 : 15 7 7 , + סהב%‎ : 二 Council 1,18156,5706 (; 

只 更 新 第 一 条 记录 : 
db .testo.update( rrCOunmt : + 805 : 10 7 7 , + ">הטסס" + : סהב%‎ : 17 1,+18156,18156 (; 


MongoDB 使 用 - remove() 落 数 删除 数据 


摘 述 


在 前 面 的 几 个 章节 中 我 们 已 经 学 习 了 MongoDB 中 如 何 为 集合 添加 数据 和 更 新 数据 。 在 本 章节 
中 我 们 将 继续 学 习 MongoDB 和 集合 的 删除 。 


MongoDB remove() 范 数 是 用 来 移 除 集合 中 的 数据 。 


MongoDB 数 据 更 新 可 以 使 用 update() 汞 数 。 在 执行 [emove() 汞 数 前 先 执行 find() 命 合 来 判 断 执 
行 的 条 件 是 否 正 确 ， 这 是 一 个 比较 好 的 习惯 。 


我 们 使 用 的 数据 库 名 称 为 "myinfo" 我 们 的 集合 名 称 为 "userdetails"， 以 下 为 我 们 插入 的 数 
据 : 


> document=({ 人 "user 10" : "testuser","password" :"testpassword" "date_of_ join” : 2 
".ג.6.א":‎ , "profession" : "CONSULTANT","interest" : "MUSIC","community_name" :["MODERN א‎ 
MUSIC", "WESTERN MUSIC"],"community_moder_id" : ["MR. BBB", "MR. JJJ", "MR MMM"],"community_ 
[500, 200, 1500], "friends_id" : ["MMM123", 05ה16ז+ ההס",["123","000123אאא"‎ 10" :["BAN123","B 


.4 na: 





> db.userdetails.insert(document) 


查看 集合 中 已 经 插入 的 数据 


> db.userdetails.find(); 


כ 
> 
”id”: ObjectIdc 4e2b6caocf54e3hbz76638e4dhbfpb">。 "user_id” : "MNOPBWN”,. "password‏ 
0 ".8.6.8" : "60068%1070" ,"16/18/2818" : "הבסך +0 8866" "MNOPBWN”,‏ : 
community_nane'” : [ "MODERN MUSIG"™,‏ ורי כ גו "intekhest”:‏ ו וה וני בו 
ינווי WUESTERN MUSIC"”]。‏ יריו כו כ כ 
] : "10 0%ח16ע+" ,[ 1588 ,288 ,588 ] : ">6ע6כה6ה ע+1הגהתסש" ,[ "אחא תא" . 
ולו ו ו ו ייוו הו רוי ור ריל ו ורי 
ליכי בוו יו A A‏ יר יל שו כ יניו 
"NEWFASSWORD”, "date._of_join™” : "1?/1@/2010",. "education” : "M.B.A.. "profe‏ : 
"MUSIG, "community_ name'” : [ "MODERN MUSIG",‏ בוו בבש כ ו ssion” : "MARKETING™,.‏ 
CLASSICAL MUSIG™, "WESTERN MUSIG™ ]. "community_moder_id” : [ "MR. BBB"”。 "MR.‏ 
YS TT 1 [ 588. 2868, 1588 PM 1 i |‏ 
] "לא" "NNN123", "000123" [, "han_friends_id' : ] "BAN123'. "BAN456",‏ ."123 
2 
בו וו כצ ב בוו וו בד קיר יקי רצו ליו ל :וינל שו כ בוני 
ו יונו ו ו מו testpbassuokhd"。 "date_of_‏ 3” 
"MODERN MUSI‏ [ : יי מ יריו כ ו : BeSSdion” : "GONSULTANT”, “interest”‏ 
ויו ”vvCLhSSICREL MUSIC"”。 “WESTERN UD i‏ 
והמו ורוי בי יי רו : I, "commnity memhers’”‏ וו וו תתו 
“hban_friends_ 18" : ] "08123", "BAN456",. "BAN?89‏ ,[ "000123" ,"3בכ2נאאא" . 





使 用 remove() 函数 移 除数 据 
如 果 你 想 移 除 "userdetails" 集 合 中 "user id" 为 "testuser" 的 数据 你 可 以 执行 以 下 命令 : 


> db.userdetails.remove( + "user 10" : "testuser" 7 ) 


删除 所 有 数据 
如 果 你 想 删 除 "userdetails" 集 合 中 的 所 有 数据 ， 可 以 执行 以 下 命令 : 


> db.userdetails.remove({}) 


使 用 drop() 删 除 集合 
如 果 你 想 删 除 整 个 "userdetails" 集 合 ， 包 含 所 有 文档 数据 ， 可 以 执行 以 下 数据 : 


> db.userdetails.drop() 


> 
> dh.userdetails.dropC> 
true 


> 
> 





drop() 汞 数 返回 true 或 者 false。 以 上 执行 结果 返回 了 true， 说 明 操 作成 功 。 


使 用 dropDatabase() 函 数 删 除数 据 库 
如 果 你 想 删 除 整 个 数据 库 的 数据 ， 你 可 以 执行 以 下 命 全 : 


> db.dropDatabase() 


行 命令 前 查看 当前 使 用 的 数据 库 是 一 个 良好 的 习惯 ， 这 样 可 以 确保 你 要 删除 数据 库 是 正确 
9， 以 免 造 成 误 操 作 而 产生 数据 丢失 的 后 果 : 


בלש 


dh.dropDatabhase> 
"dropped™” : "myinfo, " 





MongoDB 5 


הכ 
本 教程 我 们 将 向 大 家 介绍 如 何在 MongoDB 集 合 中 获取 数据 。‏ 


我 们 使 用 的 数据 库 名 称 为 "myinfo" 我 们 的 集合 名 称 为 "userdetails"， 以 下 为 我 们 插入 的 数 
据 : 


> db.userdetails.insert({"user_id" : "user1","password" :"182036" ,"0856 0% join” : 1 
, "ה0ב655זסזס"‎ : "CONSULTANT","interest" : "MUSIC","community_name" :["MODERN MUSIC", "CL 
MUSIC"],"community_moder_id" : ["MR. Alex", "MR. Dang", "MR Haris"],"community_members" 

[700, 200,1500], "friends_id" : ["kumar","harry","anand"],"ban_friends_id" :["Amir","Raja", 


0% 





> db.userdetails.insert({"user_id" : "user2","password" :"118818" , "date 0% "הבסך‎ : 1 
".ג.8.א":‎ , "profession" : "MARKETING","interest" : "MUSIC","community_name" :["MODERN MU 
MUSIC", "WESTERN MUSIC"],"community _ moder_id" : .הא"]‎ Roy", "MR. Das", "MR Doglus"],"communi 
[500, 300,1400], "friends_id" : 05ה6בז+ ההס",["ההסךן","באבט","1הק"]‎ 10" :["jalan", "monoj","e 


hh 





> db.userdetails.insert({"user_id" : "user3","password" :"bicidi" , "date 0% join” : "16/1 
:"M.C.A." , "ת65510+סזק"‎ : "IT COR.","interest™" : "ART","community_name" :["MODERN ART", 
ART"],"community_moder_id" : ["MR. Rifel", "MR. Sarma", "MR Bhatia"],"community_members" 
[5000, 2000,1500], "friends_id" : ["philip","anant","alan"],"ban_friends_id" :["Amir","Raja 


UE 





> db.userdetails.insert({"user_id" : "user4","password" :"abczyx" ,"date 0% join” : "17/8 
:"M.B.B.S." , "profession™" : "DOCTOR","interest" : "SPORTS","community_name" :["ATHELATIC 
GYES", "FAVOURIT GAMES"],"community_moder_id™" : ["MR. Paul", "MR. Das", "MR Doglus"],"commun 
05ה16ז+2500,2200,3500[,"1]‎ 10" : ["vinod","viki","john"],"ban_friends_id" :["jalan","monoj 


1 seesesssyl 


从 集合 中 获取 数据 


如 果 你 想 在 集合 中 读 取 所 有 的 的 数据 ， 可 以 执行 以 下 命令 





> db.userdetails.find(); 


类 似 于 如 下 SQL 查询 语句 : 


Select * from userdetails; 


输出 数据 如 下 所 示 : 


> 
dh.userdetails .findc<>‏ > 
₪ 。 ככ מו יוו כ תת יי i A‏ 
join : "16/18/2818", "680686107" : "8.6.8.", "profession"‏ +0 8866" ,"132365" 
"GLAS‏ יי ו "MUSIGT,‏ הריתי 
"WESTERN MUSIGC™ 1], modqekr_iqd"” : [ "MR. Alex'’. "NR. Dang"’‏ וריו כו STCAL‏ 
הח" ] : "180 PE TE‏ 1588 ,288 .780 ] : "5ע6כה6ה 9פ1%6הטההס6" .1 WE‏ 
"mont'” [ >‏ ."הרה" ,"אנחה" ] : "18 805ה16ע+ הת" ,1 "anand‏ ,"עעעהּת" 
"id :ObjectIQc'"4e367fehb449f2D8f 44a293f8 ">. useh id” : User2, "password"'’‏ 
4 ו ד ו ו רוי תו רו ו 
בי "HUSIC"”。‏ בוו בב הריו א 
" ."הת .תא" ,"עפת .תא" ] : IGAL 516", "WESTERN MUSIG™ 71, "community_moder_id‏ 
,"1" ] : "10 85ה18ע]+" ,1 1488 ,388 ,588 ] : "5ע6כת6ה ע1%הטהתפ6" ,1 
גכ [ '"ההט6" ,"ן,סהסחתח" Jalan‏ ] : "18 85ה16:] חתממ" ,1 
"user3, pasSwWokd‏ : כו 。> DOhbjectIadc'"4e367ff7449f20D8f44a29f02‏ 
profession'‏ ,".81.0.8" : "ה0ב680693%" ,"16/18/2818" : "הבפסך +0 8866" ,"16181" 
“IT COR."。，。 "intekrest"”: "community name : [ "MODERN ART", "CLASSICAL fl‏ 
T"。 "WESTERN ART™ J],. "community_moder_id : [ "MR. Rifel, "MR. Sarma'"’,‏ 
Ia ], "community_memhers'’ : [ SH06,. 20060, 15008 ],. "friends_id™” : [ philip"’,‏ 
"mont'” [ >‏ ."הרדה" "han_friends_id™” : ] "Amir,‏ .] "תהּנָהּ" ,"6תהחהג 
"5500" ,"4ע₪562" : "10 6%פט" ,כ"0766%18>"46368006449/200)44329+82 : "18 " 
"profession"‏ :וי ד ו “date_of_ join‏ יריו 
יו[ וי לצ 3 DOGTORT, intcrcast'‏ :3 
Das"'.‏ .תא" ,"אהת "HR.‏ ] : "18 אפסה GYES", "FAUOURIT 08785" 1, "conmunity‏ 
‘wvinod"’.‏ [ וו יוו ד ל צר :ךא ילל יי יל הוור כ ה 
"evan'” [ >‏ ."[סהסה" "jalan,‏ ] : "10 085ה16ע+ חהּם" ,[ "התסב" ו 


通过 指定 条 件 读 取 数据 


如 果 我 们 想 在 集合 "userdetails" 中 污 取 "education" 为 "M.C.A." 的 数据 ， 我 们 可 以 执行 以 下 命 


ב 
: כ 





> db.userdetails.find({"education":"M.C.A."}) 


类 似 如 下 SQL 查询 语句 : 


Select * from userdetails where education="M.C.A."; 


输出 结果 如 下 所 示 : 


dh.userdetails.find"education”:"M.C.A.' TP> 

" "8ב‎ 3 i 3 0 "passSwokhQ 
"12236", "88%6 0+ "הבסך‎ : "16/18/2818", "education’ : "M.C.A.'. "profession' 
"6ההּה ע+1הטההס6" ,"40516" : "65%ע662ת1" ," ז[אה5011א60'י‎ : ] "MODERN 0516", 5 
ICAL 516". "WESTERN 0516" 1, "community_moder_id' : ] .תא"‎ 016", "MR. Dang"’ 
"5כ6מקהפה ע+1הטההפס6" ,1 "5בכה] תת"‎ : ] 788, 288, 1588 A 10" : ] “kuma 


< [ '"+הפה" Raja‏ ,יבהה" ] :5 ban_friends_id'‏ ,[ "הההחהּ" ,"ענעהון" ." 


id"”: 0bhbjectIdad'"4e367ff7449f208f44a29f922>。 "user_id” : "Userd', Password'’ 
"picidi",. "date_of_join” : "16/18/2018", "הסב680068%"‎ : ".6.0.", profession'’ 
ו ו בר ו‎ "CLASSICAL 
ל וט‎ [上 "MR. Rifel'', "MR. Sarma'’,. 
"ה1:‎ [, community_members’ : ] 5888, 2888, 1588 [, "friends_id” : ] "philip", 
Rnant'’. ">הסת" ,"הר" ,"ת1הה" ] : "10 05ה216+ ההּמ" ,[ "תהּ[הּ"‎ [ > 





MongoDB 条 件 操作 符 


摘 述 
条 件 操作 符 用 于 比较 两 个 表达 式 并 从 mongoDB 和 集合 中 获取 数据 。 
在 本 章节 中 ， 我 们 将 讨论 如 何在 MongoDB 中 使 用 条 件 操作 符 。 


MongoDB 中 条 件 操作 符 有 : 


@ )< 


) 大 于 - $gt 
( 小 于 -$lt 
>=) 大 于 等 于 - $gte 


<= ) 小 于 等 于 - $lte 


@ (< 


( 
( 
( 
| 


我 们 使 用 的 数据 库 名 称 为 "myinfo" 我 们 的 集合 名 称 为 "testtable"， 以 下 为 我 们 插入 的 数据 。 


简单 的 集合 "testtable" : 


> 
> dh.testtable.find¢> 
i i ל לכבו‎ 
ו‎ :Pe TE :9 -1 ויוי ו‎ 
”3 "MGA.", "profession” : "GONSULTANI, "interest"” : "MUSIG', “extra” : € "Cc 
omnunity nane”: [ "MODERN MUSIG, "GLASSICAL MUSIC, WESTERN MUSIGC” 1],. “comnun 
hs 18" : ] .תא"‎ 816". UT "5בעה]‎ 1, ”community "פש6כ(ת6ת‎ 1 ] 
ו ד כ‎ "kumar”,. "harry'. "anand 
”1],. "hanfriends id שר )יפר 1 אש שו שי כ או הבע‎ 
" 18" : 0[166+10%"46301+16+52 082741953", ע6פש"‎ 10" : "user2", "255010" 
"113313", "56" : "316", "6צג"‎ : 24, "0866 0+ join”: "17/18/2089", 0ב‎ 
יריו בוו‎ intekhest ”3: "MUSIG, :ו‎ 
כ כ- יס מו ונינ‎ HUSIG, "WESTERN MUSIC 1]. 
ty_moder_id” 0 Doglus” ], "community_memhers' : 
. 388. 1488 [, "friends” : > "valuled friends_id” : ] "pal”, ,"1:[בט"‎ "john" 
ל ?ל [ "ההטא" ,"ך[הההחה" .,"ההוהך" ] 2 "הו 5=וההרש+ הגה"‎ + 
ה‎ : ObjectIdc 4e3dif2af52hb23hbd78374f954”，。 יו בד‎ "password’ 
הרייו ריל וב‎ "Female, age”: 19。 "datre_of_ join”: "i6/18/20106", "educat 
רשרד לייו ₪ ורוי יר + זי וו : "חסב‎ "interest. :2 "ART Maxtph. 
[ "MODERN ART”, "GCLASSICAL וה כ תו ה‎ community_moder 
- ."61+גת‎ "MR. Sarma', "MR Bhatia” ], community_nemhers’” : ] 4 
1588 [, "05ח216+"‎ : > "valued friends_id” : ] "philip”,. "anant”, "הנה"‎ ], 
">הפח" ."הּדָהת" ,"עבהה" ] : "10 05ה16ע+ הבכ"‎ [ ? > > 
ירי וש יינ רצ רא יי וו כ בוני‎ user_id™” : כו‎ "password'’ 
וי ו ו ו‎ Ed Pt a Ti TT 
"TM.B.B.$.", "profession” : "DOGTOR, "interest'” : "SPORTIS, extra : € "Cc 
וריו‎ "GAMES FAN GYES, "FAUOURIT GAMES”™ J], Cummuitly 
| moder_id : [ "MR. Paul”, "MR. Das”,. "MR Doglus” ], "community_ memhers' : [ 250 
2200。3500 ]。 friends”: ד‎ 9 
"han_friends_id” : ] “Jalan"。 כ [ "תהט6" ,"ן סהםה"‎ 2 < 





MongoDB (>) 大 于 操作 符 - % 
如 果 你 想 获取 "testtable" 集 合 中 "age" 大 于 22 的 数据 ， 你 可 以 使 用 以 下 命令 : 


> db.testtable.find({age : {$gt : 22}}) 


类 似 于 SQL 语句 : 


Select * from testtable where age >22; 


输出 结 


> 
כ2273 : 4546 : db.testtable.findage‏ > 
ילו לכו בוו ידו בד הרייו יל יי ביצי הק וי וו ב בוני 
"educatio‏ ו ו ו וו 
"MBA.",. “pofession”: “MhRKEIING"。 "interest”: MUSIC”"”。 "extra” : < "co‏ ו 
MUSIC ]- commun 革‏ אתתדפשש" nmunaIto_name' : [ "MODERN MUSIC "60551060 MUSIC‏ 


-y_moder_id” : [ ."עפת .הא"‎ "MR. ."הת‎ "MR Doglus””] “comnnunituy_memhbers"” : ] 8 
388. 1488 1, "85ה16ע+"‎ : > "valuled_friends_id” : ] ,"1ש"‎ "viki", "john' [. 

3 2 7 [ "ההטפ" ,"[ סהסה" "jalan,‏ ] : "18 05ה216+ ההּמ" 

> 

> 





MongoDB (>=) 大 于 等 于 操作 符 - $gte 
如 果 你 想 获取 "testtable" 集 合 中 "age" 大 于 等 于 22 的 数据 ， 你 可 以 执行 以 下 命 今 : 


> db.testtable.find({age : {$gte : 22}}) 


类 似 于 SQL 语句 : 


Select * from testtable where age >=22 


输出 结 


> 

> db.testtable.findage : 459686 : 22}}> 

id : Obhjectld<''4e3d1ificfS2hb9hd?8374F953"7,. "user_id : הלכו‎ massword" 
Wt -CB BE = 4 "8866 01+ יי ,"17/18/2889" : '"ה1סך‎ 

ייר ירי ארי כ ,ג אל הרי יר דיו הרי ל וע יי ו ל 

"MODERN 0516", "6055100 (516%, "WESTERN MUSIG" 1.‏ [ : "6חהּה ל16הטה 

"MR. Das,. "MR Doglus”]， "comnunity_memhers"‏ ."עפת .תא" ] : "18 אפ6אסת ל 
"john‏ ."1א%בט" ,"1הק" ] : "valuled_friends_id”‏ > : "85ה86בע+" ,1 1488 .388 

3 2 2 [ "הטפ" ,"[ סחסה" ,"ההּנַָהך" ] : "18 friends_‏ ההּמ" 


?id : Ohijectldc''4e3d1f35f52hb9hd?8374F955">, USEh_ id מ‎ "user4',. "massword" 
יי ו ב ו ו ולי‎ 
וני יווד ו‎ "intekhest”: :ו הי כ‎ 
יוו‎ "GAMES FAN GYES", "FAUOURIT GAMES™” ],. "community 
.תא" ] : "18 מפגפה‎ Paul, “MR. Das, הא"‎ Dogluac™” 1, community_ "פעפכחפה‎ : ] 8 
. 0288, 3588 1, "friends : > ."באבט" .,'"הפהבט" ] : "18 816705 הַפטְנַָהט"‎ john ] 
"han_friends_id™” : [ "jalan, 9 





MongoDB (<) 小 于 操作 符 - $lt 


如 果 你 想 获取 "testtable" 集 合 中 "age" 小 于 19 的 数据 ， 你 可 以 执行 以 下 命令 : 
类 似 于 SQL 语句 : 


Select * from testtable where age <19; 


> db.testtable.findage : 《31t :19}}> 

K "id : ObjectIdc' 4e3dltee9f52b9hbhd78374f95272>。 user_id” : "userl', "password"’ 
: "132236", "ה1ב0ך +0 0866" ,17 : "6צהּ" ,"16" : "א58"‎ : "16/18/2018" "educatio 
וו וגהנ ינ כ‎ "interest" : "MUSIC, "extra : € Cc 
ommunity_namc'’ : [ ‘MODERN MUSIGC™T, CLNSSICNL MUSICT,. WESTERN MUSIGC™” J], “commun 


ity_moder_id : [ "MR. Alex'’. "HR. Dang'’. "MR Haris” ו‎ 
86. 288, 1588 [, "friends'’ : > "valued friends_id” : ] "kumar. "harry". המאתה"‎ 
"+חסה" ,"הּדָהּת" ,"ת1הה" ] : "18 05ה16:] הבהּמ"‎ [ 2 > 了 





MongoDB )>=( 小 于 操作 符 - 6 
如 果 你 想 获取 "testtable" 集 合 中 "ager 小 于 等 于 19 的 数据 ， 你 可 以 执行 以 下 命令 : 


> db.testtable.find({age : {$lte : 19}}) 


类 似 于 SQL 语句 : 


Select * from testtable where age <=19 


输出 结 


> 

Dh.testtabhle.findtage : 45166 : 19%72‏ > 
ולב וו לכו i i‏ 
0 ,"16/18/2018" : "ה101 +0 8866" ,17 : "פאה" ,"16" : "<56" ,"36מ2הוי 

TU‏ וו וי ו כ ו וו ו מ נוי יי 

"CLASSICAL MUSIC'. "WESTERN MUSIC 1], "comnun‏ וו כ 

ity .הא" ] : "18 <66סה‎ fAlex'’. .תח"‎ Dang''. "5בעה] תוז'‎ ], "community members'” : [ 

ET |‏ 1 ו TT‏ וו הד ו 90。2009，1500 
3 2 [ "6>הסחה" "Raja'’.‏ ,"תעבה" ] : "10 05ה16ע+ חהּמ" ,1 


₪ ו וי כ : Objectldc''4e3dilif2af52h9hda?8374f954" 73, USeh_ id‏ : יו 
6 ,"16/10/2018" : "ה1ב0ך +0 0383966" ,19 : "age”‏ ,"16הה6ק" : "sex‏ ,"16181מ' : 
חחסס" > : ‘extra‏ ,"8781" : "656ע66ה1" ,".608 11" : "ה0ב655+סעם" ,".6.80.א" : 1 
"community_moder‏ ,1 "זתה "WESTERN‏ ,"זתה 6055100" ,"זתה "MODERN‏ ] : "6חהּה ע6נ1חו 
。5066 [ : ו 
"friends' : < “ualuedu_friends_ idu"”: [ ‘philip', "anant'. "alan'” ].‏ 。] 1588 ד 
?2 ? 2 [ ">הסה" ,"הּדָהּת" “ban_fhkhiends_iQ"”: ] db‏ 





MongoDB 使 用 (<) 和 (>) 查询 operator - $lt 和 $gt 
如 果 你 想 获取 "testtable" 集 合 中 "age" 大 于 17 以 及 小 于 24 的 数据 ， 你 可 以 执行 以 下 命令 : 


> db.testtable.find({age : {$lt :24, $gt : 17}}) 


类 似 于 SQL 语句 : 


Select * from testtable where age 7, 


> 
> 0%4886ה1+.%8216+665.מ8‎ : 451% :24, 546 : 177732 
i OhjectIdc 4e3dtif2af52b9hbd78374f9354”"”>。 "usekrk_id”: ו‎ DasSwWwokQ 
וו רייו כו לי‎ "Female, "age” : 19, יו‎ "educat 
ו יי ב‎ < comm 
"חהּה ע6ב1חו‎ : ] "MODERN ,"זתה 60551002" ,"זתה‎ "HESTERN ART™” 1, "community_moder 
1 [ ."61+גת .תא"‎ "MR. Sarma'’,. "MR Bhatia” [, "comnunity memhbekrs"”: ] 4. 
1588 [, "friends™” : > "valued 167005א+‎ 108" : ] “philip"” "anant, "הנה"‎ 1. 
ור בו וי‎ Eb SF mont ”> > 了 


”id”: ObjectIdc' 4e3dlf35f52b9hbd28374f955 "7。 ו ד בו ד ד‎ DaSsSSwOkG 
,"אעט>סמהּ"‎ SeX”: "Female"”。 "aqe”: 22, "date_of_ "ה1ב0ך‎ : '17/8/2009% “educat LE 
"MBaB 3" Dotesson :DOCIOR ntekeSst : "500715", "8ע06א6"‎ 2 二 
ommunity "6ההּה‎ : ] "THELATIC”, "GAMES FAN ,"5פעצב‎ "FAUOURIT 008057 1, "community 
ד ו‎ 
22009。3500 PE DD i A A 93 
"han_friends_id” : [ "jalan”, "monoj,. "evan” ] > > 》 





MongoDB 条 件 操 作 符 - $type 


摘 述 
在 本 章节 中 ， 我 们 将 继续 讨论 MongoDB 中 条 件 操作 符 $type。 
$type 操 作 符 是 基于 BSON 类 型 来 检索 集合 中 匹配 的 结果 。 


MongoDB 中 可 以 使 用 的 类 型 : 
类 型 描述 类 型 值 

Double 1 
String 2 
Object 3 
Array 4 
Binary data 5 
Object id 7 
Boolean 8 
Date כ‎ 
Null 10 
Regular expression 1 
JavaScript code 13 
Symbol 14 
JavaScript code with scope 15 
32-bit integer 16 
Timestamp 17 
64-bit integer 18 
Min key 255 
Max key 127 


我 们 使 用 的 数据 库 名 称 为 "myinfo" 我 们 的 集合 名 称 为 "testtable"， 以 下 为 我 们 插入 的 数据 。 


简单 的 集合 "testtable" : 


> 
> dh.testtable .find<> 
LE 0 ₪4 
"132236", "א56"‎ : “Hale"”。 "ספה"‎ : 17, "8866 01+ join : "16/18/2818", educatio 
ו בת‎ 7 5 CONSULTIRNI” ， "interest” וריו‎ ”bxXLid = tT"U 
omnunity_name"”: [ "MODERN HUSIC"。 "GLASSICAL MUSIC"， "WESTERN MUSIC”]。 ”comnun 
ity_moder_id” : ] .תא"‎ 816<", MR. Dang'’. "MR Haris ], "community_nembhers' : [ 
788. 208,. 1588 1, "friends” : > "valued_friends_id” : ] "kumar™”,. "harry', "anand 
" ">הסחה" ,"הנהת" ,"ע1ה)" ] : "18 85ה186ע+ חגּם" ,ן[‎ [ 2 2 》 
יי כ ד די ורי ו שיל בי ב כ יו בוני‎ 
"113313", "56%" : 
חי - '" חי‎ .BR 
ו ונ‎ 
יי‎ conmunity_mcnbers" [ 
₪. 388, 1488 [, "85ה6ב1ע?"‎ : > valuled friends_id” : ] ‘pal”, "viki", john 
85ה16ע+ חגּם"‎ 16" : ] "jalan”, "ההט6" ,"[ פהפה"‎ [ > > } 
בוו ידו בד 1 ושי כ בגל רדיק יי ביני‎ "User3, password" 
'"הב0ך +0 8866" ,19 : "6צָהּ" ,"16[החה6" : "א56" ,"16181מ"‎ : "16/18/2818", "educat 
"ה65510+סעם" .".6.4.א"‎ : "IT 608.", "8ע69א6" ,"0701" : "65%ע56ה1"‎ : > "comm 
:EL "HODERN ART", "CLASSICAL ART', "WESTERN ART™” ], conmunity_moder 
] ."61+גת .תא"‎ "MR. ."ההעה5‎ "MR Bhatia [, community_ memhers'” : ] 08. 
15808 3], "friends”™” : < "valued_friends_id” : "alan'” ], 
han_fricnds_id' : ] "7 ו וט וני בי ה של‎ » 
" id : Objectldc<4e3d1f35f52h9hbd?8374f955", user_id” : "user4d', "password"’ 
"566%" : "הב0ך +0 8866" ,22 : "6צָהּ" ,"16הה6ת"‎ : "17/8/2889", 1 
BS. "profession : "DOGCTOR", interest"™ : "SPORTS, "extra™ 2: € "Cc 
omnunity_name'” : [ "ATHELATIC,. "GAMES FAN GYES", "FAUOURI]T GANES™ J], "community 
| moder_id : ] תא" ,"5הּתע .תא" ."1טהּק .הא"‎ Doglus ], "comnunity "5ע6כח6ה‎ : [ 8 
A. 2200. 3568 3],. "friends : < "valued_ friends_id” : EL "vinod’, "viki', "john” ] 
05ה16ע1 חהּם"‎ 18" : ] "jalan, ,'"[סהסה"‎ ‘evan [ > 了 > 
ו ל ו בוני‎ user_id” : כ‎ ₪ 
יי ו‎ "education 
יי‎ Engineer', intekhest”: הי כ‎ "extra™. 2: < "Cc 
">חהּה ל16הגותה‎ : [ "ATHELATICG,. "GAMES FAN GYES", "FAUOURI]T ₪5" ] > > 


I 


0 
> 
> 





MongoDB 操作 符 - $type 实例 


如 果 想 获取 "testtable" 集合 包含 在 "extra" 中 的 "friends" 为 BSON 类 型 的 对 象 ， 你 可 以 使 用 以 


下 命令 : 


> db.testtable.find({"extra.friends" : {$type : 3}}) 


dh.testtable.find'"extra.friends'’ : Stype : 3232‏ > 
"passwora'"’‏ לכב מו ידו בד התרי יל יי לי כל ו ינבבו 
"age'’ : 17, "8366 0% join : "16/18/2818" "educatio‏ ,"16" : "א6פ" ,"132236" : 
ב בוו כ וריו כו הבור בב כו יקי וג ו וב ימ ומוי יי ה ב 
"WESJTERN MUSIDC7””]。、 “commun‏ וו כו CLASSICAL‏ ו 
"MR. Alex'. "MR. Dang'’. "MR Haris ],. "community_ members' : 上‏ [ : ה 
‘harry'. "anand‏ ,"ההש" ] : "186 1216005 "valued‏ > : "05ה6בע+" ,[ 1588 ,288 .766 

"Amir',. "Raja'. "mont' ] 3? 了 了‏ [ ויב 
שי ל ויו כו : id” Objectldc"4e3d1f1icf52b9bd7?8374f953" 3, "user_id”‏ 
0 "17/18/2089" : "ה01 FP‏ ,"113313" : 
"co‏ ו בוו “MhRKETING"。 “interest”: MUSIC"‏ ו ו ב 
MUSIC "WESTERN MUSIC” ],. "communi‏ כ ב מ וו כו 
上 5‏ ד "MR. Das'’.‏ ו ו 
"jiohn' 1].‏ ,"1אבט" ,"281" ] : "186 85ה16ע+ "valuled‏ > : "85ה16ע+" ,[ 1486 ,188 

了‏ > ? |[ "תההט6" ,"ך סהסה" ,"ההּנָהך" ] : "18 05ה16ע2+ הבּמ' 
password"‏ יו כ "user_id”‏ יי ו לי גל בי ויו ו כ רד 
"date_of _join : "16/16/2810". "educat‏ יי וו רו וו ו כו ומב 

"ART, "extra'’ : <‏ בר 
inity_name'” : [ "MODERN ART', "CLASSICAL ART'', "WESTERN ART” ],. "community_moder‏ 
id : [ "MR. Rifel', "MR. Sarma'’. "MR Bhatia J], "community_memhers'” : [ 5S@88.‏ 
"alan'” [.‏ ,"+ההחהּ" "philip”,.‏ ] : "18 05ה16ע+ valued‏ > : "85ה16ת2]" ,[ 1588 ,088 
”mont' [ 2 》 >»‏ ,"הרה" ,"יבהה" ] : "10 "hban_friends_‏ 
”id"”: 0hbjectIqac'""4e3dtf35f52hb9hbau78374Ff9557">， "user_i : usekrd4"”。 "passwohg‏ 
"age”"”: 22, "8866 0+ 0 ER od Pd‏ ,"16ה76" : "56% 
"extra : € ''c‏ כ "profession' : "001070", "interest"‏ 
pmmunity_name'’ : [ "ATHELATIC', "GAMES FAN GYESY, "FAUAURIT GAMESY J],. community‏ 
moder_id” : [ "MR. Paul1”"”。 "MR. Das. "MR Doglus ]. "community_ membhers' : [ 250‏ 
"viki', "john' ]‏ ,"הסתבט" ] : "valued_ friends_id”‏ > : "85ה6בע+" ,[ 3588 
了 2‏ 2 [ "הטש" ,"[ סהסה" ,"ה818ך" ] : "16 1168605 





更 多 实例 
查询 所 有 name 字 段 是 字符 类 型 的 数据 : 


db.users.find({name: {$type: 2}}); 


查询 所 有 age 字段 是 整 型 的 数据 : 


db.users.find({age: {$type: 167[(; 


MongoDB Limit 与 Skip 方法 


MongoDB Limit() 方法 


如 果 你 需要 在 MongoDB 中 读 取 指 定数 量 的 数据 记录 ， 可 以 使 用 MongoDB 的 Limit 方 法 ，limit() 
方法 接受 一 个 数字 参数 ， 该 参数 指定 从 MongoDB 中 读 取 的 记录 条 数 。 


语法 
limit() 方 法 基本 语法 如 下 所 示 : 


>db.COLLECTION_ NAME. find().1imit(NUMBER) 


实例 
合 myycol 中 的 数据 如 下 : 


+ " 10" : ObjectId(5983548781331adf45ec5), "title":"MongoDB Overview"} 
+ "_id" : ObjectId(5983548781331adf45ec6), "title":"NoSQL Overview"} 
+ " 10" : ObjectId(5983548781331adf45ec7), "title":"Tutorials Point Overview"} 


以 上 实例 为 显示 查询 文档 中 的 两 条 记录 : 


>db ,61616":1"+,7+)0חב+. 1סס6עח.‎ 10:0[(.1101%)2( 
{"title":"MongoDB Overview"} 

{"title":"NoSsQL Overview"} 

> 


注 : 如 果 你 们 有 指定 limit() 方 法 中 的 参数 则 显示 集合 中 的 所 有 数据 。 


MongoDB Skip() 方法 


我 们 除了 可 以 使 用 limit() 方 法 来 读 取 指定 数量 的 数据 外 ， 还 可 以 使 用 skip() 方 法 来 跳 过 指定 数量 
的 数据 ，skip 方 法 同样 接受 一 个 数字 参数 作为 跳 过 的 记录 条 数 。 


语法 
skip() 方法 脚本 语法 格式 如 下 : 


>db .COLLECTION_NAME. find().1imit(NUMBER).skip(NUMBER) 


实例 
以 上 实例 只 会 显示 第 二 条 文档 数据 


>db.mycol.find({},{"title":1,_id:0}).1imit(1).skip(1) 
{"title":"NoSsQL Overview"} 
> 


注 :skip() 方 法 默认 参数 为 0 。 


MongoDB 排序 


MongoDB sort() 方 法 


在 MongoDB 中 使 用 使 用 sort() 方 法 对 数据 进行 排序 ，sort() 方 法 可 以 通过 参数 指定 排序 的 字 
段 ， 并 使 用 1 和 -1 来 指定 排序 的 方式 ， 其 中 1 为 升序 排序 ， 而 -1 是 用 于 降序 排列 。 


语 
sort() 方 法 基本 语法 如 下 所 示 : 


>db .COLLECTION_NAME.find().sort({KEY:1}) 


实例 
myycol 集合 中 的 数据 如 下 : 


+ " 10" : 0bjectId(5983548781331adf45ec5)， "title":"MongoDB Overview"} 
+ " 10" : 00[66510)598354878133180%456066(, "51516" |050א":‎ Overview"} 
+ " 10" : 00[66%10)598354878133180%45607(, "title":"Tutorials Point Overview"} 


以 下 实例 演示 了 myycol 集合 中 的 数据 按 字段 title 的 降序 排序 : 


>db ([1-:"51%16"+)5ז10:0[(.50 ,61616":1"+,[+)0הב+. 601עח.‎ 
{"title":"Tutorials Point Overview"} 

{"title":"NoSsQL Overview"} 

{"title":"MongoDB Overview"} 

> 


注 : 如 果 没 有 指定 sort() 方 法 的 排序 方式 ， 默 认 按 照 文档 的 升序 排序 。 


MongoDB 索引 


索引 通常 能 够 极 大 的 提高 查询 的 效率 ， 如 果 没 有 索引 ，MongoDB 在 读 取 数 据 时 必须 扫描 集合 
中 的 每 个 文件 并 选取 那些 符合 查询 条 件 的 记录 。 


这 种 扫描 全 集合 的 查询 效率 是 非常 低 的 ， 特 别 在 处 理 大 量 的 数据 时 ， 查 询 可 以 要 花费 几 十 秒 
其 至 几 分 钟 ， 这 对 网 站 的 性 能 是 非常 致命 的 。 


索引 是 特殊 的 数据 结构 ， 索 引 存 储 在 一 个 易于 通 历 读 取 的 数据 集合 中 ， 索 引 是 对 数据 库 表 中 
一 列 或 多 列 的 值 进行 排序 的 一 种 结构 


ensurelndex() 方法 
MongoDB 使 用 ensurelndex() 方法 来 创建 索引 。 
语法 
ensurelndex() 方 法 基本 语法 格式 如 下 所 示 : 


>db .COLLECTION_NAME.enSsureIndex({tKEY:1}) 


语法 中 Key 值 为 你 要 创建 的 索引 字段 ，1 为 指定 按 升序 创建 索引 ， 如 果 你 想 按 降 序 来 创建 索引 
指定 为 -1 即 可 。 


实例 


>db.mycol.ensureIndex({"title":1}) 
> 


ensurelndex() 方法 中 你 也 可 以 设置 使 用 多 个 字段 创建 索引 (关系 型 数据 库 中 称 作 复合 索 
引 ) 。 


>db.mycol.ensureIndex({"title":1,"description":-1}) 
> 


ensurelndex() 接收 可 选 参 数 ， 可 选 参数 列表 如 下 : 


Parameter 


background 


unique 


name 


dropDups 


sparse 


expireAfterSeconds 


weights 


default language 


language_override 


实例 
在 后 台 创 建 索 引 : 


Type 


Boolean 


Boolean 


string 


Boolean 


Boolean 


integer 


index 
version 


document 


string 


string 


Description 


建 索 引 过 程 会 阻塞 其 它 数据 库 操 作 ，background 可 
指定 以 后 台 方 式 创建 索引 ， 即 增加 "background" 可 
选 参数 。 "background" 默认 值 为 false。 


建立 的 索引 是 否 唯一 。 指 定 为 true 创 建 唯一 索引 。 
默认 值 为 false. 


索引 的 名 称 。 如 果 未 指定 ，MongoDB 的 通过 连接 索 
引 的 字段 名 和 排序 顺序 生成 一 个 索引 名 称 。 


在 建立 唯一 索引 时 是 否 删 除 重复 记录 ,指定 true 创建 
唯一 索引 。 默 认 值 为 false. 


对 文档 中 不 存在 的 字段 数据 不 启用 索引 ; 这 个 参数 
需要 特别 注意 ， 如 果 设 置 为 true 的 话 ， 在 索引 字段 
中 不 会 查询 出 不 包含 对 应 字段 的 文档 .。 默 认 值 为 

false. 


指定 一 个 以 秒 为 单位 的 数值 ， 完 成 TTL 设 定 ， 设 定 
集合 的 生存 时 间 。 


索引 的 版 本 号 。 默 认 的 索引 版 本 取决 于 mongod 创 建 
索引 时 运行 的 版 本 。 


索引 权重 值 ， 数 值 在 1 到 99,999 之 间 ， 表 示 该 索 
引 相对 于 其 他 索引 字段 的 得 分 权重 。 


对 于 文本 索引 ， 该 参数 决定 了 停 用 词 及 词 干 和 词 器 
的 规则 的 列表 。 默认 为 英语 


对 于 文本 索引 ， 该 参数 指定 了 包含 在 文档 中 的 字段 
名 ， 语 言 履 盖 默 认 的 language， 默 认 值 为 
language. 


db.values.ensureIndex({open: 1, close: 1}, {background: true}) 


通过 在 创建 索引 时 加 background:true 的 选项 ， 让 创建 工作 在 后 台 执 行 


MongoDB 聚合 


MongoDB 中 聚合 (aggregate) 主 要 用 于 义理 数据 (诸如 统计 平均 值 , 求 和 等 )， 并 返回 计算 后 的 数 
据 结 果 。 有 点 类 似 sql 语 句 中 的 count(*)。 


aggregate() 方法 


MongoDB 中 聚合 的 方法 使 用 aggregate()。 


语法 
aggregate() 方法 的 基本 语法 格式 如 下 所 示 : 


>db .COLLECTION_NAME.aggregate(AGGREGATE_OPERATION) 


实例 


集合 中 的 数据 如 下 : 


10: ObjectId(7df78ad8902c ) 

title: "MongoDB Overview', 

description: 'MongoDB 15 no 501 08%80856', 
by_user: ,'365070001.00א'‎ 

url: 'http://www.w3cschool.cc', 

tags: ['mongodb', 'database', 'NoSQL'], 
likes: 100 


_id: ObjectId(7df78ad8902d) 

title: 'NoSQL Overview', 

description: סא'‎ 501 database 15 very fast '， 
by_user: 'w3cschool.cc', 

url: 'http://www.w3cschool.cc', 

tags: ['mongodb', 'database', 'NoSQL'], 
likes: 10 


_id: ObjectId(7df78ad8902e) 
title: [604א'‎ Overview '， 
description: [604א'‎ 15 no 501 database '， 
by_user: 'Neo4j', 
url: 'http://www.neo4j.com', 
tags: ['neo4j', 'database', 'NoSQL'], 
likes: 750 
,ד‎ 


现在 我 们 通过 以 上 集合 计算 每 个 作者 所 写 的 文章 数 ， 使 用 aggregate() 计 算 结 果 如 下 : 


> db.mycol.aggregate([{$group : + 10 : 
1 


"515": ] 
" 10" : "w3cschool.cc", 
"num_tutorial" : 2 
[604א" : הי‎ - 
"num_tutorial" : 1 

} 
,1 
1 "אס" 


\ ₪2 


"$by_user", num tutorial : {$sum : 1777[( 


以 上 实例 类 似 sql 语 句 : select by_user, count(*) from mycol group by by_user 


在 上 面 的 例子 中 ， 我 们 通过 字段 by_user 字 段 对 数据 进行 分 组 ， 并 计算 by_user 字 段 相同 值 的 


总 和 。 


下 表 展 示 了 一 些 聚 合 的 表达 式 : 


表达 式 描述 
$sum 计算 总 和 。 
$avg 计算 平均 值 


获取 集合 中 所 有 文档 对 应 


值得 最 小 值 。 

人 获取 集合 中 所 有 文档 对 应 
值得 最 大 值 。 
在 结果 文档 中 插入 值 到 一 

Spush 个 数组 让 。 : 
在 结果 文档 中 插入 值 到 一 

$addToSet ”个 数组 中 ， 但 不 创建 副 
本 。 

- 根据 资源 文档 的 排序 获取 
第 一 个 文档 数据 。 

人 根据 资源 文档 的 排序 获取 


最 后 一 个 文档 数据 


管道 的 概念 


实例 


db.mycol.aggregate([{$group : + 60 : 
"$by_user", num_tutorial : {$sum : 


"$likes"}}}]) 


db.mycol.aggregate([{$group : + 60 : 
"$by_user", num_tutorial : {$avg : 


"$likes"}}}]) 


db.mycol.aggregate([{$group : + 60 : 
"$by_user", num_tutorial : {$min : 


"$likes"}}}]) 


db.mycol.aggregate([{$group : + 60 : 
"$by_user", num_tutorial : {$max : 


"$likes"}}}]) 
db.mycol.aggregate([{$group : + id : 
"$by_user", url : {$push: "$urI"}}}]) 


db.mycol.aggregate([{$group : + id : 
"$by_user", url : {$addToSet : "$url"}}}]) 


db.mycol.aggregate([{$group : + id : 
"$by_user", first_url : {$first : "$url"}}}]) 


db.mycol.aggregate([{$group :{ id : 
"$by_user", last_url : {$last : ([(ץ?"טפ"‎ 


管道 在 Unix 和 Linux 中 一 般 用 于 将 当前 命令 的 输出 结果 作为 下 一 个 命令 的 参数 。 


MongoDB 的 聚合 管道 料 MongoDB 文 档 在 一 个 管道 处 理 完 毕 后 将 结果 传递 给 下 一 个 管道 处 理 。 
管道 操作 是 可 以 重复 的 。 


表达 式 : 处 理 输 入 文档 并 输出 。 表 达 式 是 无 状态 的 ， 只 能 用 于 计算 当前 聚合 管道 的 文档 ， 不 
能 处 理 其 它 的 文档 。 


这 里 我 们 介绍 一 下 聚合 框架 中 常用 的 几 个 操作 : 


* $project : 修改 输入 文档 的 结构 。 可 以 用 来 重 命 名 、 增 加 或 删除 域 ， 也 可 以 用 于 创建 计算 
结果 以 及 许 套 文档 。 

。 $match : 用 于 过 滤 数 据 ， 只 输出 符合 条 件 的 文档 。$match 使 用 MongoDB 的 标准 查询 操 
作 。 

> glimit : 用 来 限制 MongoDB 聚 合 管道 返回 的 文档 数 。 

。 $skip : 在 聚合 管道 中 跳 过 指定 数量 的 文档 ， 并 返回 余下 的 文档 。 

。 $unwind : 将 文档 中 的 某 一 个 数组 类 型 字段 拆 分 成 多 条 ， 每 条 包含 数组 中 的 一 个 值 。 

。 $group : 将 集合 中 的 文档 分 组 ， 可 用 于 统计 结果 。 

$sort : 将 输入 文档 排序 后 输出 。 

$geoNear : 输出 接近 某 一 地 理 位 置 的 有 序 文档 。 


管道 操作 符 实例 
1、$project 实 例 


db,article.aggregate( 
+ $project : { 
שו‎ 
author : 1 , 
}} 
); 


这 样 的 话 结 果 中 就 只 还 有 _id,tilte 和 author 三 个 字段 了 ， 默 认 情 况 下 _id 字 上 段 是 被 包含 的 ， 如 果 
要 想 不 包 含 _id 话 可 以 这 样 : 


db.article.aggregatel( 
{ $project : { 
ה‎ ON 
etl el 
author : 1 


}}); 


2.$match 实 例 


db.articles.aggregate( [ 
+ $match : + score : + $gt : 70, $lte : 90 [ 7 }, 
+ $group: + 10: null, count: + $sum: 1 7 77 
) ; 


$match 用 于 获取 分 数 大 于 70 小 于 或 等 于 90 记 录 ， 然 后 将 符合 条 件 的 记录 送 到 下 一 阶段 $group 
管道 操作 符 进行 处 理 。 


3.$skip 实 例 


db.article.aggregatel( 
+ כ61א%5%‎ : 5 [(; 


经 过 $skip 管 道 操作 符 处 理 后 ， 前 五 个 文档 被 "过 滤 " 掉 。 


MongoDB 复制 (副本 集 ) 


MongoDB 复 制 是 将 数据 同步 在 多 个 服务 器 的 过 程 。 

复制 提供 了 数据 的 宛 余 备份 ， 并 在 多 个 服务 器 上 存储 数据 副本 ， 提 高 了 数据 的 可 用 性 ， 并 可 
以 保证 数据 的 安全 性 。 

复制 还 允许 您 从 硬件 故障 和 服务 中 断 中 恢复 数据 。 


什么 是 复制 ? 


。 保障 数据 的 安全 性 

。 数据 高 可 用 性 (24*7) 

。 灾难 恢复 

* 无 需 停 机 维护 〈 如 备份， 重建 索引 ， 压 缩 ) 
* 分 布 式 读 取 数 据 


MongoDB 复 制 原理 
mongodb 的 复制 至 少 需要 两 个 节点 。 其 中 一 个 是 主 节 点 ， 负 责 处 理 客户 端 清 求 ， 其 余 的 都 是 
从 节点 ， 负 责 复制 主 节点 上 的 数据 。 


mongodb 各 个 节点 常见 的 搭配 方式 为 : 一 主 一 从 、 一 主 多 从 。 


主 节点 记录 在 其 上 的 所 有 操作 oplog， 从 节点 定期 轮 询 主 节点 获取 这 些 操 作 ， 然 后 对 自己 的 数 
据 副 本 执行 这 些 操作 ， 从 而 保证 从 节点 的 数据 与 主 节点 一 致 。 


MongoDB 复 制 结构 图 如 下 所 示 : 
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Driver 
Writes Reads 





以 上 结构 图 总 ， 客 户 端 总 主 节 点 读 取 数据 ， 在 客户 端 写 人 数据 到 主 节 点 是 ， 主 节 点 与 从 节点 
进行 数据 交互 保障 数据 的 一 致 性 。 


副本 集 特 征 : 


。 NN 个 节点 的 集群 

. 任何 节点 可 作为 主 节点 

。 所 有 写 入 操作 都 在 主 节点 上 
。 自动 故障 转移 

。 自动 恢复 


MongoDB 副 本 集 设 置 


在 本 教程 中 我 们 使 用 同一 个 MongoDB 来 做 MongoDB 主 从 的 实验 ， 操作 步骤 如 下 : 
1、 关 闭 正 在 运行 的 MongoDB 服 务 器 。 


现在 我 们 通过 指定 --replSet 选项 来 启动 mongoDB。--replSet 基本 语法 格式 如 下 : 


mongod --port "PORT" --dbpath "הדהק הדהס 8ס הטסצ"‎ --replSet "REPLICA SET_INSTANCE_ NAME" 


080 [ 


实例 
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mongod --port 27017 --dbpath "D:\set up\mongodb\data" --replSet 0 


以 上 实例 会 启动 一 个 名 为 rs0 的 MongoDB 实 例 ， 其 端口 号 为 27017。 
启动 后 打开 命令 提示 框 并 连接 上 mongoDB 服 务 。 

在 Mongo 客 户 端 使 用 命令 rs.initiate() 来 启动 一 个 新 的 副本 集 。 

我 们 可 以 使 用 rs.conf() 来 查看 副本 集 的 配置 

查看 副本 集 姿态 使 用 rs.status() 命令 


副本 集 添 加 成 员 


添加 副本 集 的 成 员 ， 我 们 需要 使 用 多 条 服务 器 来 启动 nongo 服 务 。 进 入 Mongo 客 户 端 ， 并 使 
用 rs.add() 方 法 来 添加 副本 集 的 成 员 。 


语法 
rs.add() 命令 基本 语法 格式 如 下 : 


>rs.add(HOST_NAME :PORT) 


实例 


假设 你 已 经 启动 了 一 个 名 为 mongod1.net， 端 口号 为 27017 的 Mongo 服 务 。 在 客户 端 命令 窗 
口 使 用 rs.add() 命令 将 其 添加 到 副本 集中 ， 命 令 如 下 所 示 : 


>rs.add("mongodi1.net:27017") 
> 


MongoDB 中 你 只 能 通过 主 节 点 将 Mongo 服 务 添加 到 副本 集中 ， 判断 当前 运行 的 Mongo 服 务 是 
否 为 主 节点 可 以 使 用 命令 db.isMaster() 。 

MongoDB 的 副本 集 与 我 们 常见 的 主 从 有 所 不 同 ， 主 从 在 主机 宕 机 后 所 有 服务 将 停止 ， 而 副本 
集 在 主机 宕 机 后 ， 副 本 会 接管 主 节点 成 为 主 节点 ， 不 会 出 现 宕 机 的 情况 。 


MongoDB 分 片 


分 片 
在 Mongodb 里 面 存 在 另 一 种 集群 ， 就 是 分 片 技术 ,可 以 满足 MongoDB 数 据 量 大 量 增 长 的 需求 。 


当 MongoDB 存 储 海量 的 数据 时 ， 一 台 机 器 可 能 不 足以 存储 数据 也 足以 提供 可 接受 的 读 写 吞 吐 
量 。 这 时 ， 我 们 就 可 以 通过 在 多 台 机 器 上 分 割 数据 ， 使 得 数据 库 系 统 能 存储 和 处 理 更 多 的 数 
据 。 


为 什么 使 用 分 片 


。 复制 所 有 的 写 入 操作 到 主 节 点 
延迟 的 敏感 数据 会 在 主 节 点 查询 
单个 副本 集 限制 在 12 个 节点 

* 当 请 求 量 巨大 时 会 出 现 内存 不 足 。 
。 本 地 磁 喜 不 足 

。 垂直 扩展 价格 昂贵 


MongoDB 分 片 


下 图 展示 了 在 MongoDB 中 使 用 分 片 集群 结构 分 布 : 
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上 图 中 主要 有 如 下 所 述 三 个 主要 组 件 : 
% Shard: 


用 于 存储 实际 的 数据 块 ， 实 际 生 产 环境 中 一 个 shard server 角 色 可 由 几 台 机 器 组 个 一 个 
relica set 承 担 ， 防 止 主机 单 点 故障 


。 Config Server: 
mongod 实 例 ， 存 储 了 整个 ClusterMetadata， 其 中 包括 chunk 信 息 。 
> Query Routers: 


前 端 路 由 ， 客 户 端 由 此 接 人 ， 且 让 整个 集群 看 上 去 像 单 一 数据 库 ， 前 端 应 用 可 以 透明 使 
用 。 


分 片 实例 


分 片 结构 端口 分 布 如 下 : 


Shard Server 1: 0 
Shard Server 2: 1 
Shard Server 3: 2 
Shard Server 4: 3 
Config Server : 27100 
Route Process : 40000 


步骤 一 : 启动 Shard Server 
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[root@100 /]# mkdir -p /www/mongoDB/shard/s0 
[root@100 /1]# mkdir -p /www/mongoDB/shard/s1 
[root@100 /1]# mkdir -p /ww/mongoDB/shard/s2 
[root@100 /1]# mkdir -p /ww/mongoDB/shard/s3 
[root@100 /]# mkdir -p /ww/mongoDB/shard/1log 
[root@100 /1]# /usr/local/mongoDB/bin/mongod --port 27020 --dbpath=/www/mongoDB/shard/sQ© - 


[root@100 /1]# /usr/local/mongoDB/bin/mongod --port 27023 --dbpath=/www/mongoDB/shard/s3 - 


<| ₪ 








步骤 二 : 启动 Config Server 


[root@100 /]# mkdir -p /ww/mongoDB/shard/config 
[root@100 /]# /usr/local/mongoDB/bin/mongod --port 27106 --dbpath=/www/mongoDB/shard/conf 


I | 
注意 : 这 里 我 们 完全 可 以 像 馈 动 普通 mongodb 服 务 一 样 启动 ， 不 需要 添加 一 shardsvr 和 


configsvr 参 数 。 因 为 这 两 个 参数 的 作用 就 是 改变 启动 端口 的 ， 所 以 我 们 自行 指定 了 端口 就 可 
以 。 





步骤 三 : 和 启动 Route Process 


/usr/local/mongoDB/bin/mongos --port 40000 --configdb localhost:27100 --fork --logpath=/w 
可 - . ] 


mongos 启动 参数 中 ，chunkSize 这 一 项 是 用 来 指定 chunk 的 大 小 的 ， 单 位 是 MB， 黑 认 大 小 为 
200MB. 





步骤 四 : 配置 Sharding 


接 下 来 ， 我 们 使 用 MongoDB Shell 登 录 到 mongos， 添 加 Shard 节 点 


[root@100 shard]# /usr/local/mongoDB/bin/mongo admin --port 40000 
MongoDB shell version: 2.0.7 

connecting to: 127.0.0.1:40000/admin 

mongos> db.runCommand({ addshard:"localhost:27020" }) 


+ "shardAdded" : "shardo0000", "אס"‎ : 17 

mongos> db.runcommand({ 800570870:"106817005%:27029" }) 

17 : "אס" ,"00009ז8ה5" : "shardAdded"‏ + 

mongos> db.runCommand({ enablesharding:"test" [( # 设 置 分 片 存储 的 数据 库 

} 1 : "אס" { 

mongos> db.runCommand({ shardcollection: "test.1log", key: + id:1,time:1}}) 
+ "collectionsharded" : "test.log", "אס"‎ : 7 


步骤 五 : 程序 代码 内 无 需 太 大 更 改 ， 直 接 按照 连接 普通 的 mongo 数 据 库 那 样 ， 将 数据 库 连 接 
接 入 接口 40000 


MongoDB 各 份 (mongodump) 与 恢复 
(mongorerstore) 


MongoDB 数 据 各 份 


在 Mongodb 中 我 们 使 用 mongodump 命 令 来 各 份 MongoDB 数 据 。 该 命令 可 以 导出 所 有 数据 到 
指定 目录 中 。 


mongodump 命 邻 可 以 通过 参数 指定 导出 的 数据 量 级 转 存 的 服务 器 。 


语法 
mongodump 命 令 脚 本 语法 如 下 : 


>mongodump -h dbhost -d dbname -o dbdirectory 


% -h : 

MongDB 所 在 服务 器 地 址 ， 例 如 : 127.0.0.1， 当 然 也 可 以 指定 端口 号 : 127.0.0.1:27017 
© -0 : 

需要 各 份 的 数据 库 实例 ， 例 如 : test 
© -0 : 


备份 的 数据 存放 位 置 ， 例 如 : c:\datavdump， 当 然 该 目录 需要 提前 建立 ， 在 备份 完 成 后 ， 
系统 自动 在 dump 目 录 下 建立 一 个 test 目 录 ， 这 个 目录 里 面 存放 该 数据 库 实 例 的 各 份 数 
据 。 


实例 


在 本 地 使 用 27017 启动 你 的 mongod 服 务 。 打 开 命 合 提 示 符 窗口 ， 进 入 MongoDB 安 装 目 录 的 
bin 目 录 输 入 命令 mongodump: 


>mongodump 


执行 以 上 命令 后 ， 客 户 端 会 连接 到 ip 为 127.0.0.1 端口 号 为 27017 的 MongoDB 服 务 上 ， 并 各 
份 所 有 数据 到 bin/dump/ 目录 中 。 命 令 输 出 结果 如 下 : 


ECNWindows\system32Mcmd,exe 


D:\set up\mongodb\hin>mongodump 
connected to: 127.0.0.1 
@5 i160:061:12.789 all dbs 
₪85 18:81:12.793 DATABASE: test 60 dump\test 
109:01:12 .795 test.system.indexes to dump\test\system.indexes. 


19:091:12 .797 4 ohbjects 

18:81 :8 test.my to dump\test\my.bson 

18:81: :3 @ ohbjects 

18:81 :3 Metadata for test.my to dump\test\my.metadata.js 


test-cooll to dumpNtestNcooll .hbhson‏ ו םיו 
objects‏ 1 8: 18:81 
Metadata for test.cooli to dumpNtestNcoo1ll .metad‏ 109:091:12.812 


10:091:12.814 test.mycol to dump\test\mycol.bson 
18:81: :7 2 ohbjects 
18:81 :9 Metadata for test.mycol to dump\test\mycol.metad 








mongodump 命令 可 选 参数 列表 如 下 所 示 : 


语法 描述 实例 
mongodump --host HOST_NAME 该 命令 将 备份 所 有 ”mongodump --host 
--port PORT_NUMBER MongoDB 数 据 w3cschool.cc --port 27017 


mongodump --dbpath 


mongodump --dbpath DB_PATH -- /data/db/ --out 


out BACKUP_DIRECTORY 


/data/backup/ 
mongodump --collection 该 命令 将 各 份 指定 mongodump --collection 
COLLECTION --db DB_ NAME 数据 库 的 集合 。 mycol --db test 


MongoDB 数 据 恢复 

mongodb 使 用 mongorerstore 命令 来 恢复 各 份 的 数据 。 
语法 

mongorestore 命 令 脚 本 语法 如 下 : 


>mongorestore -h dbhost -d dbname --directoryperdb dbdirectory 


% -h : 
MongoDB 所 在 服务 器 地 址 
% -dd: 


需要 恢复 的 数据 库 实例 ， 例 如 : test， 当 然 这 个 名 称 也 可 以 和 备份 时 候 的 不 一 样 ， 比 如 
test2 


> --directoryperdb : 


各 份 数据 所 在 位 置 ， 例 如 : c:\data\dump\test， 这 里 为 什么 要 多 加 一 个 test， 而 不 是 各 份 
时 候 的 dump， 读 者 自己 查看 提示 吧 ! 


e。 --drop : 


恢复 的 时 候 ， 先 删除 当前 数据 ， 然 后 恢复 各 份 的 数据 。 就 是 说 ， 恢 复 后 ， 备 份 后 添加 修 
改 的 数据 都 会 被 删除 ， 愤 用 哦 ! 


接 下 来 我 们 执行 以 下 命 兮 : 


>mongorestore 


执行 以 上 命令 输出 结果 如 下 : 


BB C:\Windows\system32\cmd.exe 


D:\set up\mongodbhb\hin>mongorestore 

connected to: 127.09.0.1 

Sat Oct @5 10:096:409.922 dump\test\cooli.bson 

Sat 066 ₪85 18:66 :4 going into namespace רד‎ 

Sat Oct 6005 160:06:40.933 warning: Restoring to test.cooli without dropping. RestolEe 


: Creating index: 《 keu:《 _id: 1 >。ns: test.coo 


18:06:41.058 dump\test\my.bson 
18:86 : 1 .8 going into namespace [test-mvy] 
18:86:41.862 warning: Restoring to test.my without dropping. Restored 
he inserted without raising errors; check vyour server log 
@5 10:06:41.063 file dump\test\my.hbson empty. skipping 
85 18:86 :41 .3 0 ב יי‎ 
₪ id ₪ > 
@5 10:096:41 .966 dump\test\mycol.bson 
₪5 18:86 :41 .7 going into namespace [test.mycol] 
@5 i106:06:41.070 warning: Restoring to test.mycol without dropping. Resto 
red data will be inserted without raising errors; check your server log 
2 ohbjects found 
586 Oct 8688 + .7 5 לי וי‎ 


Creating 186%: > key: > name: 1 >。 
60 1", name: 














MongoDB 监控 


在 你 已 经 安装 部 署 并 人 允许 MongoDB 服 务 后 ， 你 必须 要 了 解 MongoDB 的 运行 情况 ， 并 查看 
MongoDB 的 性 能 。 这 样 在 大 流量 得 情况 下 可 以 很 好 的 应 对 并 保证 MongoDB 正 常 运 作 。 


MongoDB 中 提供 了 mongostat 和 mongotop 两 个 命令 来 监控 MongoDB 的 运行 情况 。 


mongostat 命令 


mongostat 是 mongodb 自 带 的 状态 检测 工具 ， 在 命令 行 下 使 用 。 它 会 间隔 固定 时 间 获 取 
mongodb 的 当前 运行 状态 。 并 输出 。 如 果 你 发 现 数据 库 突然 变 慢 或 者 有 其 他 问题 的 话 ， 你 第 
一 手 的 操作 就 考虑 采用 mongostat 来 查看 mongo 的 状态 。 


启动 你 的 Mongod 服 务 ， 进 入 到 你 安装 的 MongoDB 目 录 下 的 bin 目 录 ， 然后 输入 mongostat 命 
令 ， 如 下 所 示 : 


D:\set up\mongodb\bin>mongostat 


以 上 命令 输出 结果 如 下 : 


C\Windows\system32\cmd.exe - mongostat 


.% a 010 8 155 4k 2 19 :4 
query update 861666 getmore command flushes mapped 6 res faults 
dhb idx miss % 4 akiaw netIn netOQut conn 1 

868 4% 
8 8 25% 
6 39 
2% 


8 4% 
4k 


5 


.% 


5 
5 


.% 0910 18 
.% 
₪ 59 

.% 2% 
9 3% 

.% 4k 
₪ 59 

.% 4k 
₪ 9 

.% 4k 
9 14.19 

4k 
₪ 4% 

4k 


a 4 
4k 


.% 


0 
x 如 
x 
0 
x 
x 各 
0 
x 各 


加 ו וו ו ו ו‎ [ey 
1: גג‎ 


.% 


加 mm Dm Dm mm mm 


5 
5 


א א א א א א א א ו NN ND‏ 


.% 8 

insert query 020866 6 command flushes 8 

locked db idx miss X / akiaw netIn netoOut conn 

9 4% 

8 4k 2 

9 14.19 
4k 


19: 20:34 


5 
5 
5 


.% 


.% 1:8 


8 
8 4 


2 
8 4 

4k 2 

oH 4k 2 
2 

2 

2 


.% 


.% 
8 4% 

-Bx 919 4k 

9 14.19 

4k 


.% 9010 


גג | 
וו ו ו ו 
גג :1 


6 59 
2% 


8 19:20:41 








mongotop 命令 


mongotop 也 是 mongodb 下 的 一 个 内 土工 具 ，mongotop 提 供 了 一 个 方法 ， 用 来 跟踪 一 个 
MongoDB 的 实例 ， 查 看 哪些 大 量 的 时 间 花 费 在 读 取 和 写 入 数据 。 mongotop 提 供 每 个 集合 的 
水 平 的 统计 数据 。 默 认 情 况 下 ，mongotop 返 回 值 的 每 一 秒 。 


启动 你 的 Mongod 服 务 ， 进 入 到 你 安装 的 MongoDB 目 录 下 的 bin 目 录 ， 然后 输入 mongotop 命 
令 ， 如 下 所 示 : 


D:\set up\mongodb\bin>mongotop 


CNWindows\system32Mcmd,exe - mongotop 


local.system.users ₪5‏ 
local.system.replset ₪5‏ 
ב ו יו 


ns write 

2₪1 3-1₪-86113 :8 
test.system.users ₪5 
local.system.users 5 
local.system.replset 5 
local.startup_log ₪5 


ns write 

G13-10-@6T13:53:29 
test.system.users ₪5 
local.system.users ₪5 
10681 .595%60 - פיי‎ 6% ₪5 
local.startup_log 5 


ns write 

2013-10-66T13:53:30 
test.system.users ₪5 
local.system.users Gms 
local.system.replset Gms 
local.startup_log ₪5 








E:\mongodb-win32-x86_64-2.2.1\bin>mongotop 90 


ע0%0פחסחה< הבר 1. 2. 64-2 86א-32חה1ש-4002חהסתי E:‏ 
connected 603: 1‏ 


ns write 

2013-83-29T04:12:17 
local.system.replset gms 
local.system.namespaces gms 
local.system.indexes gms 
admin .System-indexes gms 
admin . ₪5 
CpsCommoditylnfo.system.namespaces gms 


CpsCommoditylnfo.system.Jjs 5 


write 

20913-03-29T04:12:18 
local.system.replset 
local.system.namespaces 
local.system.indexes 
admin.system.indexes 
admin - 
CpsCommoditylnfo.system.namespaces 
CpsCommodityInfo.system.js 





后 面 的 10 是 <s/leeptime> 参 数 ， 可 以 不 使 用 ， 等 待 的 时 间 长 度 ， 以 秒 为 单位 ，mongotop 等 待 
调用 之 间 。 通 过 的 默认 mongotop 返 回 数 据 的 每 一 秒 。 


E:\mongodb-win32-x86_64-2.2.1\bin>mongotop - -5 


报告 每 个 数据 库 的 锁 的 使 用 中 ， 使 用 mongotop - 锁 ， 这 特产 生 以 下 输出 : 


E: mongodbh—-win32—x86_64-2.2.1\hbin>mongotop פע‎ -% 
connected to: תש‎ 


ab write 
2013-03-29T094:21:59 
11 


admin 
CpsCommodityIlnfo 


Qhb 
2013-03-29T04:22:00 
11 
הנחוהּ‎ 
זע +01 סח 60 כ‎ +0 


write‏ מףּ 
2013-03-29T094:22:01‏ 





输出 结果 字段 说 明 : 
* ns : 
包含 数据 库 命 名 空间 ， 后 者 结合 了 数据 库 名 称 和 集合 。 
* db : 
包含 数据 库 的 名 称 。 名 为 . 的 数据 库 针对 全 局 锁定 ， 而 非特 定数 据 库 。 
。 total : 
mongod 花 费 的 时 间 工 作 在 这 个 命名 空间 提供 总 领 。 
。 read : 
提供 了 大 量 的 时 间 ， 这 mongod 花 费 在 执行 读 操作 ， 在 此 命名 空间 。 
。 Write : 


提供 这 个 命名 空间 进行 写 操 作 ， 这 mongod 花 了 大 量 的 时 间 。 


MongoDB Java 


环境 配置 


在 Java 程 序 中 如 果 要 使 用 MongoDB， 你 需要 确保 已 经 安装 了 Java 环 境 及 MongoDB JDBC 了 驱 
动 。 


你 可 以 参考 本 站 的 Java 教 程 来 安装 Java 程 序 。 现 在 让 我 们 来 检测 你 是 否 安装 了 MongoDB 
JDBC 驱动 。 


。 首先 你 必须 下 载 mongo jar 包 ， 下 载 地 址 : https://github.com/mongodb/mongo-java- 
driver/downloads, 请 确保 下 载 最 新 版 本 。 
。 你 需要 将 mongo.jar 包 含 在 你 的 classpath 中 。。 


连接 数据 库 


连接 数据 库 ， 你 需要 指定 数据 库 名 称 ， 如 果 指 定 的 数据 库 不 存在 ，mongo 会 自动 创建 数据 
库 。 


连接 数据 库 的 Java 代 码 如 下 : 


import com.mongodb .MongoClient ; 
import com.mongodb.MongoException,; 
import com.mongodb .WriteCconcern 
import com.mongodb.DB; 

import com.mongodb.DBCollection,; 
import com.mongodb.BasicDBObject; 
import com.mongodb.DBObject; 
import com.mongodb .DBCursor ; 
import com.mongodb.ServerAddress; 
import java.util.Arrays; 


public 61855 MongoDBJDBC{ 
public static void main( String args[] (+ 
try{ 
// 连接 到 mongodb 服务 
MongoClient mongoClient = new MongoClient( "localhost" , 27017 ) 
// 连接 到 数据 库 
DB db = mongoClient.getDB( "test" ); 
System.out.println("Connect to database successfully"); 
boolean auth = db.authenticate(myUserName, myPassword); 
System.out.println("Authentication: "+auth); 
}catch(Exception e){ 
System.err.println( e.getClass().getName() + ": " + e.getMessage() (; 
} 
} 
} 


现在 ， 让 我 们 来 编译 运行 程序 并 创建 数据 库 test。 


你 可 以 更 加 你 的 实际 环境 改变 MongoDB JDBC 了 驱动 的 路 径 。 


本 实例 笃 MongoDB JDBC 和 启动 包 mongo-2.10.1.jar 放 在 本 地 目录 下 : 


$javac MongoDBJDBC. java 

$java -classpath ".:mongo-2.10.1.jar" MongoDBJDBC 
Connect to database successfully 

Authentication: true 


如 果 你 使 用 的 是 Window 系 统 ， 你 可 以 按 以 下 命令 来 编译 执行 程序 : 


$javac MongoDBJDBC. java 

$java -classpath ".;mongo-2.10.1.jar" MongoDBJDBC 
Connect to database successfully 

Authentication: true 


如 果 用 户 名 及 密码 正确 ， 则 Authentication 的 值 为 true。 


创建 集合 


我 们 可 以 使 用 com.mongodb.DB 类 中 的 createCollection() 来 创建 集合 
代码 片段 如 下 : 


import com.mongodb.MongoClient; 
import com.mongodb.MongoException; 
import com.mongodb.writeConcern,; 
import com.mongodb .DB; 

import com.mongodb.DBCollection,; 
import com.mongodb.BasicDBObject; 
import com.mongodb.DBObject; 
import com.mongodb .DBCursor; 
import com.mongodb.ServerAddress; 
Import java.util.Arrays; 


public 61855 MongoDBJDBC{ 
public static void main( String args[] (+ 
try{ 
// 连接 到 mongodb 服务 
MongoClient mongoClient = new MongoClient( "localhost" , 27017 (; 
// 连接 到 数据 库 
DB db = mongoClient.getDB( "test" ); 
System.out.println("Connect to database successfully"); 
boolean auth = db.authenticate(myUserName, myPassword); 
System.out.println("Authentication: "+auth); 
DBCollection 6011 = db.createCollection("mycol"); 
System.out.println("Collection created successfully"); 
}catch(Exception e){ 
System.err.println( e.getClass().getName() + ": " + e.getMessage() (; 
} 


} 
} 


编译 运行 以 上 程序 ， 输 出 结果 如 下 : 


Connect to database successfully 
Authentication: true 
Collection created successfully 


获取 集合 


我 们 可 以 使 用 com.mongodb.DBCollection 类 的 getCollection() 方法 来 获取 一 个 集合 


代码 片段 如 下 : 


import com.mongodb .MongoClient ; 
import com.mongodb.MongoException; 
import com.mongodb .WriteCconcern 
Import com.mongodb .DB; 

import com.mongodb.DBCollection,; 
import com.mongodb . 8851608001 60% ; 
import com.mongodb . 6%; 
import com.mongodb .DBCursor ; 
import com.mongodb .ServerAddress ; 
import java,Uutil.Arrays ; 


public 61855 MongoDBJDBC{ 
public static void main( String args[] ){ 


} 


} 


try{ 
// 连接 到 mongodb 服务 
MongoClient mongoClient = new MongoClient( "localhost" , 27017 (; 
// 连接 到 数据 库 
DB db = mongoClient.getDB( "test" ); 
System.out.println("Connect to database successfully"); 
boolean auth = db.authenticate(myUserName, myPassword); 
System.out.println("Authentication: "+auth); 
DBCollection 6011 = db.createCollection("mycol"); 
System.out.println("Collection created successfully"); 
DBCollection 6011 = db.getCollection("mycol"); 
System.out.println("Collection mycol selected successfully"); 
}catch(Exception e){ 
System.err.println( e.getClass().getName() + ": " + e.getMessage() (; 
1 


编译 运行 以 上 程序 ， 输 出 结果 如 下 : 


Connect to database successfully 
Authentication: true 

Collection created successfully 
Collection mycol selected successfully 


插入 文档 


我 们 可 以 使 用 com.mongodb.DBCollection 类 的 insert() 方法 来 插入 一 个 文档 
代码 片段 如 下 : 


import com.mongodb .MongoClient ; 
import com.mongodb.MongoException; 
import com.mongodb .WriteCconcern ; 
Import com.mongodb .DB; 

import com.mongodb.DBCollection; 
import com.mongodb . 285160800 60 
import com.mongodb . 0%; 
import com.mongodb .DBCursor ; 
import com.mongodb .ServerAddress ; 
Import java.util.Arrays; 


public 61855 MongoDBJDBC{ 
public static void main( String args[] (+ 
tryt{ 
// 连接 到 mongodb 服务 
MongoClient mongoClient = new MongoClient( "localhost" , 27017 (; 
// 连接 到 数据 库 
DB db = mongoClient.getDB( "test" ); 
System.out.println("Connect to database successfully"); 
boolean auth = db.authenticate(myUserName, myPassword); 
System.out.println("Authentication: "+auth); 
DBCollection 6011 = db.getCollection("mycol"); 
System.out.println("Collection mycol selected successfully"); 
BasicDBObject doc = new BasicDBObject("title", "MongoDB"). 
append("description", "database"). 
append("likes", 100). 
append("url", "http://www.w3cschool.cc/mongodb/"). 
append("by", "w3cschool.cc"); 
coll.insert(doc); 
System.out.println("Document inserted successfully"); 
}catch(Exception e){ 
System.err.println( e.getClass().getName() + ": " + e.getMessage() (; 
} 


} 
} 


编译 运行 以 上 程序 ， 输 出 结果 如 下 : 


Connect to database successfully 
Authentication: true 

Collection mycol selected successfully 
Document inserted successfully 


检索 所 有 文档 
我 们 可 以 使 用 com.mongodb.DBCollection 类 中 的 find() 方法 来 获取 集合 中 的 所 有 文档 。 
此 方法 返回 一 个 游标 ， 所 以 你 需要 通 历 这 个 游标 。 


代码 片段 如 下 : 


import com.mongodb .MongoClient ; 
import com.mongodb.MongoException; 
import com.mongodb .WriteCconcern ; 
Import com.mongodb .DB; 

import com.mongodb.DBCollection; 
import com.mongodb . 285160800 60 
import com.mongodb . 0%; 
import com.mongodb .DBCursor ; 
import com.mongodb .ServerAddress ; 
Import java.util.Arrays; 


public 61855 MongoDBJDBC{ 
public static void main( String args[] (+ 
try{ 
// 连接 到 mongodb 服务 
MongoClient mongoClient = new MongoClient( "localhost" , 27017 (; 
// 连接 到 数据 库 
DB db = mongoClient.getDB( "test" ); 
System.out.println("Connect to database successfully"); 
boolean auth = db.authenticate(myUserName, myPassword); 
System.out.println("Authentication: "+auth); 
DBCollection 6011 = db.getCollection("mycol"); 
System.out.println("Collection mycol selected successfully"); 
DBCursor cursor = coll.find(); 
18% 11; 
while (cursor.hasNext()) { 
System.out,println("Inserted Document: "+i); 
System.out.println(cursor.next()); 
1++; 


}catch(Exception e){ 
System.err.println( e.getClass().getName() + ": " + e.getMessage() (; 
} 


编译 运行 以 上 程序 ， 输 出 结果 如 下 : 


Connect to database successfully 
Authentication: true 

Collection mycol selected successfully 
Inserted Document: 1 


{ 
" 10" : ObjectId(7df78ad8902c), 
"title": "MongoDB", 
"description": "database", 
"likes": 100, 
"url": "http://www.w3cschool.cc/mongodb/", 
"by": "w3cschool.cc" 
} 


更 新 文档 


你 可 以 使 用 com.mongodb.DBCollection 类 中 的 update() 方法 来 更 新 集合 中 的 文档 。 
代码 片段 如 下 : 


import com.mongodb .MongoClient ; 
import com.mongodb.MongoException; 
import com.mongodb .WriteCconcern ; 
Import com.mongodb .DB; 

import com.mongodb.DBCollection; 
import com.mongodb . 285160800 60 
import com.mongodb . 0%; 
import com.mongodb .DBCursor ; 
import com.mongodb .ServerAddress ; 
Import java.util.Arrays; 


public 61855 MongoDBJDBC{ 


public static void main( String args[] ){ 
try{ 
// 连接 到 Mongodb 服 务 


MongoClient mongoClient = new MongoClient( "localhost" , 27017 (; 


// 连接 到 你 的 数据 库 
DB db = mongoClient.getDB( "test" ); 


System.out.println("Connect to database successfully"); 
boolean auth = db.authenticate(myUserName, myPassword); 


System.out.println("Authentication: "+auth); 
DBCollection 6011 = db.getCollection("mycol"); 


System.out.println("Collection mycol selected successfully"); 


DBCursor cursor = coll.find(); 

while (cursor.hasNext()) { 
DBObject updateDocument = cursor.next(); 
updateDocument .put("likes","200") 
col1.update(updateDocument ) ; 


System.out.println("Document updated successfully"); 


cursor = 6011.+100)(; 

1% 11; 

while (cursor.hasNext()) { 
System.out.println("Updated Document: "+i); 
System.out.println(cursor.next()); 
1++; 


}catch(Exception e){ 


} 


System.err.println( e.getClass().getName() + ": 


编译 运行 以 上 程序 ， 输 出 结果 如 下 : 


Connect to database successfully 
Authentication: true 

Collection mycol selected successfully 
Document updated successfully 

Updated Document: 1 


{ 


" 10" : ObjectId(7df78ad8902c), 

"title": "MongoDB", 

"description": "database", 

"likes": 100, 

"url": "http://www.w3cschool.cc/mongodb/", 
"by": "w3cschool.cc" 


删除 第 一 个 文档 


" + e.getMessage() (; 


要 删除 集合 中 的 第 一 个 文档 ， 首 先 你 需要 使 用 com.mongodb.DBCollection 类 中 的 findOne() 方 
法 来 获取 第 一 个 文档 ， 然 后 使 用 remove 方法 删除 。 


代码 片段 如 下 : 


Import com,mongodb .MongoClient ; 
Import com.mongodb.MongoException; 
Import com.mongodb .WriteCconcern ; 
Import com.mongodb.DB; 
import com.mongodb .DBCoJlJection， 
import com.mongodb.BasicDBObject; 
import com.mongodb.DBObject; 
import com.mongodb.DBCursor; 
import com.mongodb.ServerAddress; 
Import java.util.Arrays,; 


public 61855 MongoDBJDBC{ 
public static void main( String args[] ){ 
try{ 
// 连接 到 Mongodb 服 务 
MongoClient mongoClient = new MongoClient( "localhost" , 27017 ) 
// 连接 到 你 的 数据 库 
DB db = mongoClient.getDB( "6655" (; 
System.out.println("Connect to database ;("ץ50006551011‎ 
boolean auth = db.authenticate(myUserName, myPassword); 
System.out.println("Authentication: "+auth); 
DBCollection 6011 = db.getCollection("mycol"); 
System.out.println("Collection mycol selected successfully"); 
DBObject myDoc = coll.findone(); 
col1.remove(myDoc ( ; 
DBCursor cursor = coll.find(); 
%ח1‎ 1; 
while (cursor.hasNext()) { 
System.out,println("Inserted Document: "+i); 
System.out.println(cursor.next()); 
1++; 
1 
System.out.println("Document 0616560 successfully"); 
}catch(Exception e){ 
System,.err.println( e.getClass().getName() + ": " + e.getMessage() ); 
} 


} 
} 


编译 运行 以 上 程序 ， 输 出 结果 如 下 : 


Connect to database successfully 
Authentication: true 

Collection mycol selected successfully 
Document deleted successfully 


你 还 可 以 使 用 save(), limit(), skip(), sort() 等 方法 来 操作 MongoDB 数 据 库 。 


MongoDB PHP 


在 php 中 使 用 mongodb 你 必须 使 用 mongodb 的 php 驱 动 。 


MongoDB PHP 在 各 平台 上 的 安装 及 驱动 包 下载 请 查看 :PHP 安 装 MongoDB 扩 展 驱 动 


确保 连接 及 选择 一 个 数据 库 


为 了 确保 正确 连接 ， 你 需要 指定 数据 库 名 ， 如 果 数 据 库 在 mongoDB 中 不 存在 ，mongoDB 会 自 
动 创建 


代码 片段 如 下 : 


<?php 
// 连接 到 mongodb 
$m = new MongoClient(); 
echo "Connection to database successfully"; 
// 选择 一 个 数据 库 
$db = $m->mydb; 
echo "Database mydb selected"; 
?< 


执行 以 上 程序 ， 输 出 结果 如 下 : 


Connection to database successfully 
Database mydb selected 


创建 集合 
创建 集合 的 代码 片段 如 下 : 


<?php 
// 连接 到 mongodb 
$m = new MongoClient(); 
echo "Connection to database successfully"; 
// 选择 一 个 数据 库 
$db = $m->mydb; 
echo "Database mydb selected"; 
$collection = $db->createCollection("mycol"); 
echo "Collection created succsessfully"; 
?> 


执行 以 上 程序 ， 输 出 结果 如 下 : 


Connection to database ץ50006551011‎ 
Database סע‎ 0 
Collection created succsessfully 


插入 文档 


在 mongoDB 中 使 用 insert() 方法 插入 文档 : 
插入 文档 代码 片段 如 下 : 


<?php 
// 连接 到 mongodb 
$m = new MongoClient(); 
echo "Connection to database successfully"; 
// 选择 一 个 数据 库 
$db = $m->mydb; 
echo "Database mydb selected"; 
$collection = $db->mycol; 
echo "Collection selected succsessfully"; 
$document = array( 
"title" => "MongoDB", 
"description" => "database", 
"likes" => 100, 
"url™ => "http://www.w3cschool.cc/mongodb/", 
"by", "w3cschool.cc" 
); 
$collection->insert($document); 
echo "Document inserted successfully"; 
?> 


执行 以 上 程序 ， 输 出 结果 如 下 : 


Connection to database successfully 
Database mydb selected 

Collection selected succsessfully 
Document inserted successfully 


查找 文档 


使 用 find() 方法 来 读 取 集合 中 的 文档 。 
读 取 使 用 文档 的 代码 片段 如 下 : 


<?php 
// 连接 到 mongodb 
$m = new MongoClient(); 
echo "Connection to database successfully"; 
// 选择 一 个 数据 库 
$db = $m->mydb; 
echo "Database mydb selected"; 
$collection = $db->mycol; 
echo "Collection selected succsessfully"; 


$cursor = $collection->find(); 

// 迭代 显示 文档 标题 

foreach ($cursor as $document) { 
echo $document["title"] . "\n"; 

} 


?> 


执行 以 上 程序 ， 输 出 结果 如 下 : 


Connection to database ץ50006551011‎ 
Database mydb selected 
Collection 56160560 succsessfully 


"title": "MongoDB" 


更 新 文档 


使 用 update() 方法 来 更 新 文档 。 
以 下 实例 将 更 新 文档 中 的 标题 为 ' MongoDB Tutorial'， 代码 片段 如 下 : 


<pre> 
<?php 
// 连接 到 mongodb 
$m = new MongoClient(); 
echo "Connection to database successfully"; 
// 选择 一 个 数据 库 
$db = $m->mydb; 
echo "Database mydb selected"; 
$collection = $db->mycol; 
echo "Collection selected succsessfully"; 


// 更 新 文档 
$collection->update(array("title"=>"MongoDB"), array('$set'=>array("title"=>"MongoDB ד‎ 
echo "Document updated successfully"; 
// 显示 更 新 后 的 文档 
$cursor = $collection->find(); 
// 循环 显示 文档 标题 
echo "Updated document "; 
foreach ($cursor as $document) + 
echo $document["title"] . "ח\"‎ ; 


} 


He = 了 
执行 以 上 程序 ， 输 出 结果 如 下 : 





Connection to database successfully 
Database mydb selected 

Collection selected succsessfully 
Document updated successfully 
Updated document 


"title": "MongoDB Tutorial" 


删除 文档 


使 用 remove() 方法 来 删除 文档 。 
以 下 实例 中 我 们 将 移 除 'title' 为 "MongoDB Tutorial' 的 数据 记录 。， 代码 片段 如 下 : 


<?php 
// 连接 到 mongodb 
$m = new MongoClient(); 
echo "Connection to database successfully"; 
// 选择 一 个 数据 库 
$db = $m->mydb; 
echo "Database mydb selected"; 
$collection = $db->mycol; 
echo "Collection selected succsessfully"; 


// 移 除 文档 
$collection->remove(array("title"=>"MongoDB Tutorial"),false); 
echo "Documents deleted successfully"; 


// 显示 可 用 文档 数据 
$cursor = $collection->find(); 
// iterate cursor to display title of documents 
echo "Updated document"; 
foreach ($cursor as $document) { 
echo $document["title"] . "\n"; 
} 


?> 


执行 以 上 程序 ， 输 出 结果 如 下 : 


Connection to database successfully 
Database mydb selected 

Collection selected succsessfully 
Documents deleted successfully 


除了 以 上 实例 外 ， 在 php 中 你 还 可 以 使 用 findOne(), save(), limit(), skip(), sort() 等 方法 来 操作 
Mongodb 数 据 库 。 


MongoDB <% 


MongoDB 的 关系 表示 多 个 文档 之 间 在 逻辑 上 的 相互 联系 。 
文档 间 可 以 通过 嵌入 和 引用 来 建立 联系 。 
MongoDB 中 的 关系 可 以 是 : 


* 1:1 (1 对 1) 

。 1: N (1 对 多 ) 
. א‎ 1 (多 对 1) 
。 N: N (多 对 多 ) 


接 下 来 我 们 来 考虑 下 用 户 与 用 户 地 址 的 关系 。 

一 个 用 户 可 以 有 多 个 地 址 ， 所 以 是 一 对 多 的 关系 。 

以 下 是 user 文档 的 简单 结构 : 
"id":0bjectId("52ffc33cd85242f436000001" ( , 
"name": "Tom Hanks", 


"contact": "987654321", 
"dob": "01-01-1991" 


以 下 是 address 文档 的 简单 结构 : 


"id":0bjectId("52ffc4a5d85242602e000000" ( , 
"building": "22 A, Indiana Apt", 

"pincode": 123456, 

"city": "Los Angeles", 

"state": "California" 


% ב א 


:בכ << מ 5 א וטו = מ עס 3% ,לכל \ב.\? אנ 5 


"id":0bjectId("52ffc33cd85242f436000001" ( , 
"contact": "987654321", 
"600": "01-01-1991", 


"name": "Tom Benzamin", 
"8007655": [ 


"building": "22 ,ה‎ Indiana Apt", 
"pincode": 123456, 
"city": "Los Angeles", 


"state": "California" 
,ד‎ 
"building": "1760 ,"%קה 867000115 ,ה‎ 
"pincode": : 92 
"city": "616800" , 
"55856": "11117015" 
}] 


以 上 数据 保存 在 单一 的 文档 中 ， 可 以 比较 容易 的 获取 很 维护 数据 。 你 可 以 这 样 查询 用 户 的 地 
址 : 


>db.users.findone({"name":"Tom Benzamin"},{"address":1}) 


注意 : 以 上 查询 中 db 和 users 表示 数据 库 和 集合 
这 种 数据 结构 的 缺点 是 ， 如 果 用 户 和 用 户 地 址 在 不 断 增加 ， 数 据 量 不 断 变 大 ， 会 影响 读 写 性 


5 
6 


引用 式 关 系 


引用 式 关 系 是 设计 数据 库 时 经 常用 到 的 方法 ， 这 种 方法 把 用 户 数 据 文档 和 用 户 地 址 数据 文档 
分 开 ， 通 过 引用 文档 的 id 字段 来 建立 关系 。 


"id":0bjectId("52ffc33cd85242f436000001" ( , 

"contact": "987654321", 

"600": "01-01-1991", 

"name": "Tom Benzamin", 

"address_ids": 
ObjectId("52ffc4a5d85242602e000000" ( , 
00[166%10)"521164850852426026000001" ( 

1 

1 


以 上 实例 中 ， 用 户 文档 的 address_ids 字段 包含 用 户 地 址 的 对 象 id (Objectld) 4 
我 们 可 以 读 取 这 些 用 户 地 址 的 对 象 id (Objectld) 来 获取 用 户 的 详细 地 址 信息 。 


这 种 方法 需要 两 次 查询 ， 第 一 次 查询 用 户 地 址 的 对 象 id (Objectld) ， 第 二 次 通过 查询 的 id 获 
取 用 户 的 详细 地 址 信息 。 


>var result = db.users.findone({"name":"Tom Benzamin"},{"address_ids":1}) 
>var addresses = db.address.find({"_id":{"$in":result["address_ids"]}}) 


MongoDB 数据 库 引 用 


在 上 一 章节 MongoDB 关 系 中 我 们 提 到 了 MongoDB 的 引用 来 规范 数据 结构 文档 。 
MongoDB 引用 有 两 种 : 


> 手动 引用 (Manual References) 
e DBRefs 


DBRefs vs 手动 引用 


考虑 这 样 的 一 个 场景 ， 我 们 在 不 同 的 集合 中 (address_home, address_office， 
address_mailing, 等 ) 存 储 不 同 的 地 址 〈 住 址 ， 办 公 室 地 址 ， 邮 件 地 址 等 ) 。 


这 样 ， 我 们 在 调用 不 同 地 址 时 ， 也 需要 指定 集合 ， 一 个 文档 从 多 个 集合 引用 文档 ， 我 们 应 该 
使 用 DBRefs。 


使 用 DBRefs 
DBRef 的 形式 : 


(ESref : , %10 : , 800 : 7 


三 个 字段 表示 的 意义 为 : 


* $ref : 集合 名 称 
% $id : 引用 的 id 
* $db: 数 据 库 名 称 ， 可 选 参数 


以 下 实例 中 用 户 数据 文档 使 用 了 DBRef, 字段 address : 


{ 
"_id":0ObjectId("53402597d852426020000002")， 


"address": { 

"$ref": "address home", 

"$id": 00[66%10)"534009640852427820000002" ( , 
"600" : "w3cschoolcc"}, 

"contact": "987654321", 

"600": "01-01-1991", 

"name": "Tom Benzamin" 


address DBRef 字段 指定 了 引用 的 地 址 文档 是 在 address_home 集合 下 的 w3cschoolcc 数据 
库 ，id 为 534009e4d852427820000002。 


以 下 代码 中 ， 我 们 通过 指定 $ref 参数 (address_home 集合 ) 来 查找 集合 中 指定 id 的 用 户 地 
址 信息 : 


>var user = db.users.findone({"name":"Tom Benzamin"}) 
>var dbRef = user.address 
>db[dbrRef.$ref].findone({"_id":(dbRef.$id)}) 


以 上 实例 返回 了 address_home 集合 中 的 地 址 数据 : 


" 10" : 00[66%10)"534009640852427820000002" ( , 
"building" : "22 ,ה‎ Indiana Apt", 

"pincode" : 123456, 

Angeles‏ 105" : "ץ616" 

"55866" : "California" 
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官方 的 MongoDB 的 文档 中 说 明 ， 有 覆盖 查询 是 以 下 的 查询 : 


。 所 有 的 查询 字段 是 索引 的 一 部 分 
。 所 有 的 查询 返回 字段 在 同一 个 索引 中 


由 于 所 有 出 现在 查询 中 的 字段 是 索引 的 一 部 分 ， MongoDB 无 需 在 整个 数据 文档 中 检索 匹配 
查询 条 件 和 返回 使 用 相同 素 引 的 查询 结果 。 


为 索引 存在 于 RAM 中 ， 从 素 引 中 获取 数据 比 通过 扫描 文档 读 取 数据 要 快 得 多 。 


使 用 履 盖 索引 查询 


为 了 测试 盖 索 引 查 询 ， 使 用 以 下 users 集合 : 


"_id": 00[66%10)"534025970852426020000002" ( , 
"contact": "987654321", 

"600": "01-01-1991", 

"gender " : ייא"‎ , 

"name": "Tom Benzamin", 

"user_name": "tombenzamin" 


我 们 在 users 集合 中 创建 联合 索引 ， 字 段 为 gender 和 user_name : 


>db.users.ensureIndex({gender:1,user_name:1}) 


现在 ， 该 索引 会 覆盖 以 下 查询 : 

>db.users.find({gender:"M"}, {user_name:1,_id:0}) 
也 就 是 说 ， 对 于 上 述 查 询 ，MongoDB 的 不 会 去 数据 库 文 件 中 查找 。 相 反 ， 它 会 从 索引 中 提取 
数据 ， 这 是 非常 快速 的 数据 查询 。 


由 于 我 们 的 索引 中 不 包括 _id 字段 ，_id 在 查询 中 会 默认 返回 ， 我 们 可 以 在 MongoDB 的 查询 结 
果 集 中 排除 它 。 


下 面 的 实例 没有 排除 _id， 查 询 就 不 会 被 覆盖 : 


>db.users.find({gender:"M"}, {user_name:1}) 


最 后 ， 如 果 是 以 下 的 查询 ， 不 能 使 用 覆盖 索引 查询 : 


。 所 有 索引 字段 是 一 个 数组 


MongoDB 查询 分 析 


MongoDB 查询 分 析 可 以 确保 我 们 建议 的 索引 是 否 有 效 ， 是 查询 语句 性 能 分 析 的 重要 工具 。 


MongoDB 查询 分 析 常 用 函数 有 : explain() 和 hint()。 


使 用 explain() 


explain 操作 提供 了 查询 信息 ， 使 用 索引 及 查询 统计 等 。 有 利于 我 们 对 索引 的 优化 。 
接 下 来 我 们 在 users 集合 中 创建 gender 和 user_name 的 索引 : 


>db.users.ensureIndex({gender:1,user_name:1}) 

</p> 

<p> 现 在 在 查询 语句 中 使 用 explain :</p> 

<pre> 

>db.users.find({gender:"M"}, {user_name:1,_id:0}).explain() 


以 上 的 explain() 查询 返回 如 下 结果 : 


name 1",‏ ז₪56 1 ז06ה06 "BtreeCursor‏ : "זספזט6" 
"isMultikey" : 6,‏ 
1% :"הח" 
"nscannedobjects" : 6,‏ 
"nscanned" : 1,‏ 
"nscannedobjectsAllPlans" : 6,‏ 
"nscannedAllPlans" : 1,‏ 
"scanAndorder" : 6,‏ 
"indexOnly" : true,‏ 
"nYields" : 0,‏ 
"nChunkSkips" : 0,‏ 
"millis” : 6,‏ 
"indexBounds" : +‏ 

"gender" : |[ 


WM 
יא"‎ 

1 

"user_name" : ] 
[ 
"$minElement" : 1 

}, 
{ 


"$maxElement" : 1 


现在 ， 我 们 看 看 这 个 结果 集 的 字段 : 


* indexOnly: 字段 为 true ， 表 示 我 们 使 用 了 索引 。 

* cursor : 因为 这 个 查询 使 用 了 索引 ，MongoDB 中 索引 存储 在 B 树 结构 中 ， 所 以 这 是 也 使 
用 了 BtreeCursor 类 型 的 游标 。 如 果 没 有 使 用 索引 ， 游 标的 类 型 是 BasicCursor。 这 个 键 还 
会 给 出 你 所 使 用 的 索引 的 名 称 ， 你 通过 这 个 名 称 可 以 查看 当前 数据 库 下 的 system.indexes 
集合 〈 系 统 自动 创建 ， 由 于 存储 索引 信息 ， 这 个 稍微 会 提 到 ) 来 得 到 索引 的 详细 信息 。 

* :ה‎ 当前 查询 返回 的 文档 数量 。 

。 nscanned/nscannedObjects : 表明 当前 这 次 查询 一 共 扫描 了 集合 中 多 少 个 文档 ， 我 们 
的 目的 是 ， 让 这 个 数值 和 返回 文档 的 数量 越 接近 越 好 。 

。 millis : 当前 查询 所 需 时 间 ， 毫 秒 数 。 

。 indexBounds : 当前 查询 具体 使 用 的 索引 。 


使 用 hint() 


虽然 MongoDB 查 询 优 化 器 一 般 工 作 的 很 不 错 ， 但 是 也 可 以 使 用 hints 来 强迫 MongoDB 使 用 一 
个 指定 的 索引 。 


这 种 方法 某 些 情形 下 会 提升 性 能 。 一 个 有 索引 的 collection 并 且 执 行 一 个 多 字段 的 查询 (一 些 字 
段 已 经 索引 了 )。 


如 下 查询 实例 指定 了 使 用 gender 和 user_name 索引 字段 来 查询 : 


>db.users.find({gender:"M"}, {user_name:1,_id:0}).hint({gender:1,user_name:1}) 


可 以 使 用 explain() 函数 来 分 析 以 上 查询 : 


>db.users.find({gender:"M"}, {user_name:1,_id:0}).hint({gender:1,user_name:1}).explain() 


到 


MongoDB 原子 操作 

mongodb 不 支持 事务 ， 所 以 ， 在 你 的 项 目 中 应 用 时 ， 要 注意 这 点 。 无 论 什 么 设计 ， 都 不 要 要 
求 mongodb 保 证 数据 的 完整 性 。 

但 是 mongodb 提 供 了 许多 原子 操作 ， 比 如 文档 的 保存 ， 修 改 ， 删 除 等 ， 都 是 原子 操作 。 


所 谓 原子 操作 就 是 要 么 这 个 文档 保存 到 Mongodb， 要 么 没有 保存 到 Mongodb， 不 会 出 现 查 询 
到 的 文档 没有 保存 完整 的 情况 。 


原子 操作 数据 模型 


考虑 下 面 的 例子 ， 图 书馆 的 书籍 及 结账 信息 。 


实例 说 明了 在 一 个 相同 的 文档 中 如 何 确保 嵌入 字段 关联 原子 操作 (update : 更 新 ) 的 字段 是 
同步 的 。 


book = { 
16: 9 
61616: "MongoDB: The Definitive 60106", 
author: ] "Kristina Chodorow", "Mike Dirolf" [, 
published_ 0856: ISODate("2010-09-24")， 
pages: 216, 
language: "English", 
publisher_id: "oreilly", 
available: 3, 
checkout: ] + by: "joe", date: 15008%6)"2012-10-15"( } [ 
} 


你 可 以 使 用 db.collection.findAndModify() 方法 来 判断 书籍 是 否 可 结算 并 更 新 新 的 结算 信息 。 
在 同一 个 文档 中 人 入 的 available 和 checkout 字段 来 确保 这 些 字段 是 同步 更 新 的 : 


db.books.findAndModify ) + 
query: { 
_id: 123456789, 
available: { $gt: © } 


}, 
update: { 
$inc: { available: -1 }, 
$push: + checkout: + by: "abc", date: new Date() } 7 
} 
} ) 


原子 操作 音 用 命令 


$set 


用 来 指定 一 个 键 并 更 新 键 值 ， 若 键 不 存在 并 创建 。 
+ 856% : + field : value [ } 


$unset 


用 来 删除 一 个 键 。 


+ $unset : + field : 1} } 

$inc 

$inc 可 以 对 文档 的 某 个 值 为 数字 型 (只 能 为 满足 要 求 的 数字 ) 的 键 进行 增 减 的 操作 。 
+ $inc : + field : value } } 

$push 

用 法 : 


+ $push : + 11810 : value [ } 


把 value 追 加 到 field 里 面 去 ，field 一 定 要 是 数组 类 型 才 行 ， 如 果 field 不 存在 ， 会 新 增 一 个 数组 类 
型 加 进去 。 


$pushAll 


同 $push, 只 是 一 次 可 以 追加 多 个 值 到 一 个 数组 字段 内 。 
+ $pushAl1 : + field : value array [ } 


$pull 
从 数组 field 内 删除 一 个 等 于 value 值 。 


+ $pull : + 11610 : _value } 7 


$addToSet 
增加 一 个 值 到 数组 内 ， 而 且 只 有 当 这 个 值 不 在 数组 内 才 增 加 。 


$pop 
删除 数组 的 第 一 个 或 最 后 一 个 元 素 


{ $pop : { field :1 }} 


$rename 
修改 字段 名 称 


{ $rename : { old field name : new field name } } 


$bit 
位 操作 ，integer 类 型 


{$bit : { field : {and : 5}}} 


偏 移 操作 符 


> t.find() + " 10" : ObjectId("4b97e62bf1id8c7152c9ccb74"), "title" : "ABC", "comments" 
> t.update( {'comments.by':'joe'}, {$inc:{'comments.$.votes':1}}, false, true ) 


> t.find() + " 10" : ObjectId("4b97e62bf1id8c7152c9ccb74"), "title" : "ABC", "comments" 


₪ - 3 





MongoDB 高 级 索引 


考虑 以 下 文档 集合 (users ) : 


"8007655" : { 
"city": "105 Angeles", 
"state": "California", 
"pincode": "123" 


"tags": [ 
"music", 
ב‎ 
"blogs" 

1, 


"name": "Tom Benzamin" 


} 


以 上 文档 包含 了 address 子 文档 和 tags 数组 。 


索引 数组 字段 


假设 我 们 基于 标签 来 检索 用 户 ， 为 此 我 们 需要 对 集合 中 的 数组 tags 建立 索引 。 


在 数组 中 创建 索引， 需要 对 数组 中 的 每 个 字段 依次 建立 素 引 。 所 以 在 我 们 为 数组 tags 创建 索 
引 时 ， 会 为 music、cricket、blogs 三 个 值 建立 单独 的 索引 。 


使 用 以 下 命令 创建 数组 索引 : 


>db.users.ensureIndex({"tags":1}) 


创建 索引 后 ， 我 们 可 以 这 样 检索 集合 的 tags 字段 : 


>db.users.find({tags:"cricket"}) 


为 了 验证 我 们 使 用 使 用 了 索引 ， 可 以 使 用 explain 命令 : 


>db.users.find({tags:"cricket"}).explain() 


以 上 命令 执行 结果 中 会 显示 "cursor" : "BtreeCursor tags_1" ， 则 表示 已 经 使 用 了 素 引 。 


来 引子 文档 字段 


假设 我 们 需要 通过 city、state、pincode 字 段 来 检索 文档 ， 由 于 这 些 字段 是 子 文档 的 字段 ， 所 
以 我 们 需要 对 子 文档 建立 索引 。 


为 子 文档 的 三 个 字段 创建 索引 ， 命 合 如 下 : 


>db.users.ensureIndex({"address.city":1,"address.state":1,"address.pincode":1}) 


一 且 创 建 索 引 ， 我 们 可 以 使 用 子 文档 的 字段 来 检索 数据 : 


>db.users.find({"address.city":"Los Angeles"}) 


记 住 查询 表达 式 必 须 遵循 指 定 的 索引 的 顺序 。 所 以 上 面 创 建 的 索引 将 支持 以 下 查询 : 


>db.users.find({"address.city":"Los Angeles", "address.state":"California"}) 


同样 支持 以 下 查询 : 


>db.users.find({"address.city":"LosAngeles", "address.state":"California", "address.pincode 





MongoDB 索引 限制 
额外 开销 


每 个 素 引 占据 一 定 的 存储 空间 ， 在 进行 插入 ， 更 新 和 删除 操作 时 也 需要 对 索引 进行 操作 。 所 
以 ， 如 果 你 很 少 对 集合 进行 读 取 操 作 ， 建 议 不 使 用 索引 。 


内 存 (RAM) 使 用 


由 于 索引 是 存储 在 内 存 (RAM) 中 ,你 应 该 确保 该 索引 的 大 小 不 超过 内 存 的 限制 。 
如 果 素 引 的 大 小 大 于 内 存 的 限制 ，MongoDB 会 删除 一 些 索引， 这 将 导致 性 能 下 降 。 


查询 限制 


索引 不 能 被 以 下 的 查询 使 用 : 


> 正则 表达 式 及 非 操 作 符 ， 如 $nin, $not, 等 。 
。 算术 运算 符 ， 如 $mod, 等 。 
。 $where 子 句 


所 以 ， 检 测 你 的 语句 是 否 使 用 索引 是 一 个 好 的 习惯 ， 可 以 用 explain 来 查看 。 


素 引 键 限 制 


从 2.6 版 本 开始 ， 如 果 现 有 的 索引 字段 的 值 超过 索引 键 的 限制 ，MongoDB 中 不 会 创建 索引 。 


插入 文档 超过 素 引 键 限制 


如 果 文 档 的 索引 字段 值 超过 了 索引 键 的 限制 ，MongoDB 不 会 将 任何 文档 转换 成 索引 的 集合 。 
与 mongorestore 和 mongoimport 工 具 类 似 。 


最 大 泄 围 


。 集合 中 来 引 不 能 超过 64 个 
。 索引 名 的 长 度 不 能 超过 125 个 字符 
。 一 个 复合 索引 最 多 可 以 有 31 个 字段 


MongoDB Objectld 


在 前 面 几 个 章节 中 我 们 已 经 使 用 了 MongoDB 的 对 象 Id(Objectld)。 
在 本 章节 中 ， 我 们 将 了 解 的 Objectld 的 结构 。 
Objectld 是 一 个 12 字 节 BSON 类 型 数据 ， 有 以 下 格式 : 


* 前 4 个 字 节 表示 时 间 戳 

* 接 下 来 的 3 个 字 节 是 机 器 标识 码 

. 紧 接 的 两 个 字 节 由 进程 id 组 成 〈PID) 
。 最 后 三 个 字 节 是 随机 数 。 


MongoDB 中 存储 的 文档 必须 有 一 个 " id" 键 。 这 个 键 的 值 可 以 是 任何 类 型 的 ， 默 认 是 个 
Objectld 对 象 。 


在 一 个 集合 里 面 ， 每 个 集合 都 有 唯一 的 "id" 值 ， 来 确保 集合 里 面 每 个 文档 都 能 被 唯一 标识 。 


MongoDB 采 用 Objectld， 而 不 是 其 他 比较 常规 的 做 法 〈 比 如 自动 增加 的 主键 ) 的 主要 原因 ， 
因为 在 多 个 服务 器 上 同步 自动 增加 主键 值 既 费力 还 费时 。 


创建 信 的 Objectld 

使 用 以 下 代码 生成 新 的 Objectld : 
>newObjectId = ObjectId() 

上 面 的 语句 返回 以 下 唯一 生成 的 id : 
objectId("5349b4ddd2781d08c09890f3 7” ( 


你 也 可 以 使 用 生成 的 id 来 取代 MongoDB 自 动 生 成 的 Objectld : 


>myObjectId = 00166%10)"53490400027810086098901%4"( 


1 


由 于 Objectld 中 存储 了 4 个 字 节 的 时 间 戳 ， 所 以 你 不 需要 为 你 的 文档 保存 时 间 惟 字段， 你 可 
以 通过 getTimestamp 画 数 来 获取 文档 的 创建 时 间 : 


>0bjectId("5349b4ddd2781d08c09890f4").getTimestamp() 


以 上 代码 将 返回 ISO 格式 的 文档 创建 时 间 : 


15008%6)"2014-04-121721:49:172"( 


Objectld 转换 为 字符 串 

在 某 些 情况 下 ， 您 可 能 需要 将 Objectld 转 换 为 字符 串 格式 。 你 可 以 使 用 下 面 的 代码 : 
>new ObjectId.str 

以 上 代码 将 返回 Guid 格 式 的 字符 串 : : 


5349b4ddd2781d08c09890f3 


MongoDB Map Reduce 


Map-Reduce 是 一 种 计算 模型 ， 简 单 的 说 就 是 将 大 批量 的 工作 (数据 ) 分 解 (MAP) 执行 ， 然 
后 再 将 结果 合并 成 最 终结 果 (REDUCE) 。 


MongoDB 提 供 的 Map-Reduce 非 常 灵 活 ， 对 于 大 规模 数据 分 析 也 相当 实用 。 


MapReduce 命 兮 
以 下 是 MapReduce 的 基本 语法 : 


>db .collection.mapReduce( 
function() {emit(key,value);},， //map 画 数 
function(key,values) {return reduceFunction}, //reduce 画 数 


out: collection, 
query: document, 


sort: document, 
limit: number 


使 用 MapReduce 要 实现 两 个 函数 Map 978 Reduce 辑 数 ,Map 男 数 调用 emit(key, value)， 
通 历 collection 中 所 有 的 记录 , 将 key 与 value 传递 给 Reduce 辑 数 进行 处 理 。 


画 数 必须 调用 emit(key, value) 返回 键 值 对 。‏ סבו 
参数 说 明 :‏ 


* map : 映射 男 数 (生成 键 值 对 序列 ,作为 reduce 86 

。 reduce 统计 回 数 ，reduce 男 数 的 任务 就 是 将 key-values 交 成 key-value， 也 就 是 把 values 
数组 变 成 一 个 单一 的 值 value。。 

* out 统计 结果 存放 集合 (不 指定 则 使 用 临时 集合 ,在 客户 端 断 开 后 自动 删除 )。 

。 query 一 个 筛选 条 件 ， 只 有 满足 条 件 的 文档 才 会 调用 map 函 数 。 (query。limit，sort 可 以 


随意 组 合 ) 
。 sort 和 limit 结 合 的 sort 排 序 参数 (也 是 在 发 往 map 汞 数 前 给 文档 排序 ) ， 可 以 优化 分 组 机 
制 


> limit 发 往 map 丁 数 的 文档 数量 的 上 限 (要 是 没有 Ilimit， 单 独 使 用 sort 的 用 处 不 大 ) 


使 用 MapReduce 


考虑 以 下 文档 结构 存储 用 户 的 文章 ， 文 档 存 储 了 用 户 的 user_name 和 文章 的 status 字 段 : 


"post_text": "w3cschool.cc 菜 乌 教程 ， 最 全 的 技术 文档 。"， 
"User_name": "mark", 
"status":"active" 


现在 ， 我 们 将 在 posts 集合 中 使 用 mapReduce 画 数 来 选取 已 发 布 的 文章 ， 
分 组 ， 计 算 每 个 用 户 的 文章 数 : 


>db .posts,mapReduce( 
function() + emit(this.user_id,1); }, 
function(key, values) {return Array.sum(values)}, 
{ 
query:{status:"active"}, 
out:"post_total" 
} 


以 上 mapReduce 输出 结果 为 : 


{ 
"result" : "post_total", 
"timeMillis" : 9, 
"counts" : + 
Ut 
"emit" : 4, 
"reduce"” : 2, 
"output" : 2 
}, 
"אס"‎ : 10 
} 


并 通过 user_name 


结果 表明 ， 共 有 4 个 符合 查询 条 件 (status:"active") 的 文档 ， 在 map 函 数 中 生成 了 4 个 键 值 对 


文档 ， 最 后 使 用 reduce 函 数 将 相同 的 键 值 分 为 两 组 。 
具体 参数 说 明 : 


。 result : 储存 结果 的 collection 的 名 字 , 这 是 个 临时 集合 ，MapReduce 的 连接 关闭 后 自动 就 


被 删除 了 。 
。 timeMillis : 执行 花费 的 时 间 ， 窒 秒 为 单位 
> input : 满足 条 件 被 发 送 到 map 画 数 的 文档 个 数 


> emit : 在 map 辑 数 中 emit 被 调用 的 次 数 ， 也 就 是 所 有 集合 中 的 数据 总 量 


* ouput : 结果 集合 中 的 文档 个 数 (count 对 调试 非常 有 帮助 ) 
。 ok : 是 否 成 功 ， 成 功 为 1 


。 err : 如 果 失 败 ， 这 里 可 以 有 失败 原因 ， 不 过 从 经 验 上 来 看 ， 原 因 上 比较 模糊 ， 作 用 不 大 


使 用 find 操作 符 来 查看 mapReduce 的 查询 结 


>db .posts,mapReduce( 
function() + emit(this.user_id,1); }, 
function(key, values) {return Array.sum(values)}, 


{ 
query:{status:"active"}, 
out:"post_total" 


} 
) .find() 
以 上 查询 显示 如 下 结果 ， 两 个 用 户 tom 和 mark 有 两 个 发 布 的 文章 : 


[] 2 : "6ט1העט" ,"חס>" : "0ב " + 
]7 2 : "6ט1הע" ,"אזהת" : "10 " + 


用 类 似 的 方式 ，MapReduce 可 以 被 用 来 构建 大 型 复杂 的 聚合 查询 。 


Map 轴 数 和 Reduce 男 数 可 以 使 用 JavaScript 来 实现 ， 是 的 MapReduce 的 使 用 非常 灵活 和 强 
大 。 


MongoDB 全 文 检索 


全 文 检索 对 每 一 个 词 建 立 一 个 索引 ， 指 明 该 词 在 文章 中 出 现 的 次 数 和 位 置 ， 当 用 户 查 询 时 ， 
检索 程序 就 根据 事先 建立 的 索引 进行 查找 ， 并 将 查找 的 结果 反馈 给 用 户 的 检索 方式 。 


这 个 过 程 类 似 于 通过 字典 中 的 检索 字 表 坦 字 的 过 程 。 
MongoDB 从 2.4 版 本 开始 支持 全 文 检索 ， 目 前 支持 15 种 语言 (暂时 不 支持 中 文 ) 的 全 文 索 引 。 


> danish 

> dutch 

> english 

> finnish 

。 french 

* german 

> hungarian 
e italian 

> norwegian 
e portuguese 
。 romanian 
> russian 

> Spanish 

e。 swedish 
e turkish 


启用 全 文 检索 


MongoDB 在 2.6 版 本 以 后 是 默认 开启 全 文 检索 的 ， 如 果 你 使 用 之 前 的 版 本 ， 你 需要 使 用 以 下 
代码 来 启用 全 文 检索 : 


>db.adminCommand({setParameter:true, textSearchEnabled:true}) 


或 者 使 用 命令 : 


mongod --SetParameter textSearchEnabled=true 


创建 全 文 索引 


考虑 以 下 posts 集合 的 文档 数据 ， 包 含 了 文章 内 容 (post_text) 及 标签 (tags) : 


"post_text": "enjoy the mongodb articles חס‎ w3cschool.cc", 
"5805": ] 

"mongodb", 

"w3cschool" 


我 们 可 以 对 post text 字段 建立 全 文 素 引 ， 这 样 我 们 可 以 搜索 文章 内 的 内 容 : 


>db.posts.ensureIndex({post_text:"text"}) 


使 用 全 文 素 引 


现在 我 们 已 经 对 post_text 建立 了 全 文 素 引 ， 我 们 可 以 搜索 文章 中 的 关键 词 w3cschool.cc : 


>db.posts.find({$text:{$search:"w3cschool.cc"}}) 


以 下 命 合 返回 了 如 下 包含 w3cschool.cc 关 键 词 的 文档 数据 : 


{ 
" 10" : ObjectId("53493d14d852429c10000002")， 
"post_text" : "enjoy the mongodb articles חס‎ w3cschool.cc", 
"tags" : [ "mongodb", "w3cschool" [ 
} 
{ 
" 10" : objectId("53493d1fd852429c10000003" ( , 
"post_text" : "writing tutorials חס‎ ₪305070001.00", 
"6805" : ] "mongodb", "tutorial" ] 
} 


如 果 你 使 用 的 是 旧版 本 的 MongoDB， 你 可 以 使 用 以 下 命令 : 


>db.posts.runCcommand("text", {search:" w3cschool.cc"}) 


使 用 全 文 索引 可 以 提高 搜索 效率 。 


删除 全 文 索引 


删除 已 存在 的 全 文 素 引 ， 可 以 使 用 find 命令 查找 索引 名 : 


>db.posts.getIindexes() 


通过 以 上 命令 获取 索引 名 ， 本 例 的 索引 名 为 post_ text_ text， 执 行 以 下 命令 来 删除 素 引 : 


W3School MongoDB 教程 


>db.posts.dropIndex("post_text_text") 
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MongoDB 正则 表达 式 

正则 表达 式 是 使 用 单个 字符 串 来 描述 、 匹 配 一 系列 符合 某 个 句法 规则 的 字符 串 。 
许多 程序 设计 语言 都 支持 利用 正则 表达 式 进行 字符 串 操作 。 

MongoDB 使 用 $regex 操作 符 来 设置 匹配 字符 串 的 正则 表达 式 。 


ווח 


MongoDB 使 用 PCRE (Perl Compatible Regular Expression) 作为 正则 表达 式 语 
不 同 于 全 文 检索 ， 我 们 使 用 正则 表达 式 不 需要 做 任何 配置 。 
考虑 以 下 posts 集合 的 文档 结构 ， 该 文档 包含 了 文章 内 容 和 标签 : 


"post_text": "enjoy the mongodb articles on tutorialspoint", 
"tags": [ 

"mongodb", 

"tutorialspoint" 


] 
} 


使 用 正则 表达 式 

以 下 命令 使 用 正则 表达 式 查 找 包 含 w3cschool.cc 字符 串 的 文章 : 
>db.posts.find({post_text:{$regex:"w3cschool.cc"}}) 

以 上 查询 也 可 以 写 为 : 


>db.posts.find({post_text:/w3cschool.cc/}) 


不 区 分 大 小 写 的 正则 表达 式 
如 果 检 索 需 要 不 区 分 大 小 写 ， 我 们 可 以 设置 $options 为 $i。 


以 下 命令 将 查找 不 区 分 大 小 写 的 字符 串 w3cschool.cc : 


>db.posts.find({post_text:{$regex:"w3cschool.cc", $options:"$i"}}) 


集合 中 会 返回 所 有 包含 字符 串 w3cschool.cc 的 数据 ， 且 不 区 分 大 小 写 : 


{ 
"_id" : ObjectId("53493d37d852429c10000004")， 


"post_text" : "hey! this 15 my post on W3Cschool.cc", 
"tags" : ] "tutorialspoint" [ 
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我 们 还 可 以 在 数组 字段 中 使 用 正则 表达 式 来 查找 内 容 。 这 在 标签 的 实现 上 非常 有 用 ， 如 果 你 
需要 查找 包含 以 tutorial 开头 的 标签 数据 (tutorial 或 tutorials 或 tutorialpoint 或 tutorialphp)， 
你 可 以 使 用 以 下 代码 : 


>db.posts.find({tags:{$regex:"tutorial"}}) 


优化 正则 表达 式 查 询 


* 如 果 你 的 文档 中 字段 设置 了 索引 ， 那 么 使 用 索引 相 比 于 正则 表达 式 匹 配 查 找 所 有 的 数据 
查询 速度 更 快 。 

。 如 果 正 则 表达 式 是 前 级 表达 式 ， 所 有 匹配 的 数据 将 以 指定 的 前 级 字符 串 为 开始 。 例 如 : 
如 果 正 则 表达 式 为 Atut ， 查 询 语句 将 查找 以 tut 为 开头 的 字符 串 。 


MongoDB 管理 工具 : Rockmongo 


RockMongo 是 PHP5 写 的 一 个 MongoDB 管 理工 具 。 
通过 Rockmongo 你 可 以 管理 MongoDB 了 服务， 数据库， 集合， 文档， 索引 等 等 。 
它 提供 了 非常 人 性 化 的 操作 。 类 似 phpMyAdmin (PHP 开 发 的 MySql 管 理工 具 ) 。 


Rockmongo 下 载 地 址 : http://rockmongo.com/downloads 
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* 使 用 宽松 的 New BSD License 协 议 
。 速度 快 ， 安 装 简单 
. 支持 多 语言 (目前 提供 中 文 、 英 文 、 日 文 、 巴 西 葡萄 牙 语 、 法 语 、 德 语 、 俄 语 、 意 大 利 


o 可 以 配置 多 个 主机 ， 每 个 主机 可 以 有 多 个 管理 员 

o 需要 管理 员 密 码 才能 登 和 操作， 确保 数据 库 的 安全 性 
。 服务 器 

o 服务 器 信息 (WEB 服 务 器 , PHP, PHP.ini 相 关 指 邻 …) 

o 状态 


0 数据库 信息 


。 数据 库 
0 查询 ， 创 建 和 删除 
o 执行 命 舍 和 Javascript 代 码 
0 统计 信息 
。 集合 (相当 于 表 ) 
o 强大 的 查询 工具 
o 读数 据 ， 写 数据 ， 更 改 数据 ， 复 制 数 据 ， 删 除数 据 
0 查询 、 创 建 和 删除 索引 
0 清空 数据 
o 批量 删除 和 更 改 数据 
0 统计 信息 
e。 GridFS 
o 查看 分 块 
5 下 载 文件 


ch | 士 
安装 


。 一 个 能 运行 PHP 的 Web 服 务 器 ， 上 比如 Apache Httpd, Nginx ... 
。 PHP - 需要 PHP v5.1.6 或 更 高 版 本 ， 需 要 支持 SESSION 
o 为 了 能 连接 MongoDB， 你 需要 安装 php_mongo 扩 展 


快速 安装 
下 


载 安装 包 
解压 到 你 的 网 站 目录 下 
用 编辑 器 打开 config.php， 修 改 host, port, admins 等 参数 
。 在 浏览 器 中 访问 index.php， 比 如 说 : http://localhost/rockmongo/index.php 
。 使 用 用 户 名 和 密码 登录 ， 默 认为 "admin" 和 "admin" 
* 开始 玩 转 MongoDBI! 


参考 文章 : http://rockmongo.com/wiki/introduction?lang=zh_cn 


MongoDB GridFS 


GridFS 用 于 存储 和 恢复 那些 超过 16M (BSON 文 件 限 制 ) 的 文件 (如 : 图 片 、 音 频 、 视 频 等 )。 
GridFS 也 是 文件 存储 的 一 种 方式 ， 但 是 它 是 存储 在 MonoDB 的 集合 中 。 
GridFS 可 以 更 好 的 存储 大 于 16M 的 文件 。 


GridFS 会 特大 文件 对 象 分 割 成 多 个 小 的 chunk( 文 件 片 段 ), 一 般 为 256k/ 个 ,每 个 chunk 将 作为 
MongoDB 的 一 个 文档 (document) 被 存储 在 chunks 集 合 中 。 


GridFS 用 两 个 集合 来 存储 一 个 文件 : fs.files 与 fs.chunks。 


每 个 文件 的 实际 内 容 被 存在 chunks( 二 进 制 数据 ) 中 ,和 文件 有 关 的 meta 数 据 
(filename,content_type, 还 有 用 户 自 定义 的 属性 ) 将 会 被 存在 files 集 合 中 。 


以 下 是 简单 的 fs.files 集合 文档 : 


{ 
"filename": "test.txt", 
"chunkSize": NumberInt(261120), 
"uploadDate": 15008%6)"2014-04-13111:32:33.5572"(, 
"md5": "7b762939321e146569b07f72c62cca4f'"， 
"length": NumberInt(646) 

} 


以 下 是 简单 的 fs.chunks 集合 文档 : 


"files_id": ObjectId("534a75d19f54bfec8a2fe44b"), 
:"תח"‎ NumberInt(0), 
"data": "Mongo Binary Data" 


} 


GridFS 添加 文件 


现在 我 们 使 用 GridFS 的 put 命令 来 存储 mp3 文件 。 调用 MongoDB 安装 目录 下 bin 的 
mongofiles.exe 工 具 。 

打开 命令 提示 符 ， 进 入 到 MongoDB 的 安装 目录 的 bin 目 录 中 ， 找 到 mongofiles.exe， 并 输入 下 
面 的 代码 : 


>mongofiles.exe -d gridfs put 3 


GridFS 是 存储 文件 的 数据 名 称 。 如 果 不 存 在 该 数据 库 ，MongoDB 会 自动 创建 。Song.mp3 是 
音频 文件 名 。 


使 用 以 下 命令 来 查看 数据 库 中 文件 的 文档 : 


>db.fs.files.find() 


以 上 命令 执行 后 返回 以 下 文档 数据 : 


_id: ObjectId('534a811bf8b4aa4d33fdf94d ( , 

filename: "song.mp3", 

chunkSize: 261120, 

uploadDate: new Date(1397391643474), md5: "e4f53379c909f7bed2e9d631e1i5c1c41", 
length: 10401959 


我 们 可 以 看 到 fs.chunks 集合 中 所 有 的 区 块 ， 以 下 我 们 得 到 了 文件 的 _id 值 ， 我 们 可 以 根据 这 
个 _id 获取 区 块 (chunk) 的 数据 : 


>db .fs,chunks.find({tfiles_id:objectId('" 534a811bf8b4aa4d33fdf94d ' )}) 


以 上 实例 中 ， 查 询 返 回 了 40 个 文档 的 数据 ， 意 味 着 mp3 文 件 被 存储 在 40 个 区 块 中 。 


MongoDB 固定 集合 (Capped Collections) 


MongoDB 固定 集合 (Capped Collections) 是 性 能 出 色 的 有 着 固定 大 小 的 集合 ， 对 于 大 小 固 
定 ， 我 们 可 以 想象 其 就 像 一 个 环形 队列 ， 当 集合 空间 用 完 后 ， 再 插入 的 元 素 就 会 覆盖 最 初始 
的 头 部 的 元 素 ! 


全‏ ב 
创建 固定 集合‏ 
我 们 通过 createCollection 来 创建 一 个 固定 集合 ， 且 capped 选 项 设置 为 true :‏ 


>db.createCollection("cappedLogCollection", {capped:true, size:10000}) 


还 可 以 指定 文档 个 数 , 加 上 max:1000 属 性 : 
>db.createCollection("cappedLogCollection", {capped:true, size:10000,max:1000}) 
判断 集合 是 否 为 固定 集合 : 
>db.cappedLogCollection.isCapped() 


如 果 需 要 将 已 存在 的 集合 转换 为 固定 集合 可 以 使 用 以 下 命令 : 


>db.runCcommand({"convertToCapped":"posts",size:10000}) 


以 上 代码 将 我 们 已 存在 的 posts 集合 转换 为 固定 集合 。 


固定 集合 查询 


固定 集合 文档 按照 插入 顺序 储存 的 ,默认 情况 下 查询 就 是 按照 插入 顺序 返回 的 ,也 可 以 使 用 
$natural 调 整 返 回 顺 序 。 


>db.cappedLogCollection.find().sort({$natural:-1}) 


固定 集合 的 功能 特 后 


可 以 插入 及 更 新 ,但 更 新 不 能 超出 collection 的 大 小 ,否则 更 新 失败 ,不 允许 删除 ,但 是 可 以 调用 
drop() 删 除 集合 中 的 所 有 行 ,但 是 drop 后 需要 显 式 地 重建 集合 。 


在 32 位 机 子 上 一 个 cappped collection 的 最 大 值 约 为 482.5M,64 位 上 只 受 系统 文件 大 小 的 限 
制 。 


固定 集合 属性 及 用 法 
属性 
。 属性 1 对 固定 集合 进行 插入 速度 极 忆 
。 属性 2: 按 照 插入 顺序 的 查询 输出 速度 极 忆 


。 属性 3: 能 够 在 插入 最 新 数据 时 ,淘汰 最 早 的 数据 


用 法 


. 用 法 1: 储存 日 日 志 信 息 
* 用 法 2: 缓 存 一 些 少量 的 文档 


MongoDB 自动 增长 


MongoDB 没有 像 SQL 一 样 有 自动 增长 的 功能 ， MongoDB 的 _id 是 系统 自动 生成 的 12 字 节 
唯一 标识 。 
但 在 某 些 情况 下 ， 我 们 可 以 需要 实现 Objectld 实现 自动 增长 功能 。 


由 于 MongoDB 没有 实现 这 个 功能 ， 我 们 可 以 通过 编程 的 方式 来 实现 ， 以 下 我 们 将 在 
counters 集合 中 实现 id 字段 自动 增长 。 


使 用 counters 集合 


考虑 以 下 products 文档 。 我 们 希望 _id 字段 实现 从 1,2,3,4 到 mn 的 自动 增长 功能 。 


10 : יי 
"product_name": "Apple iPhone",‏ 
"category": "mobiles"‏ 


} 


为 此 ， 创 建 counters 集合 ， 序 列 字 段 值 可 以 实现 自动 长 : 


>db.createCollection("counters") 
现在 我 们 向 counters 集合 中 插入 以 下 文档 ， 使 用 productid 作为 key: 


"_id":"productid", 


"sequence_value": 0 


sequence_value 字段 是 序列 的 是 通过 自动 增长 后 的 一 个 值 。 


使 用 以 下 命令 插入 counters 集合 的 序列 文档 中 : 


>db.counters.insert({_id:"productid",sequence value:0}) 


创建 Javascript 辑 数 


现在 ， 我 们 创建 函数 getNextSequenceValue 来 作为 序列 名 的 输入 ， 指定 的 序列 会 自动 增长 
1 并 返回 最 新 序列 值 。 在 本 文 的 实例 中 序列 名 为 productid 。 


>function getNextSequenceValue(sequenceName){ 
Var sequenceDocument = db.counters.findAndModify( 


{ 
query:{_id: sequenceName }, 
update: {$inc:{sequence_ value:1}}, 
new:true 

}); 


return sequenceDocument.sequence_value; 


} 


使 用 Javascript 函数 


接 下 来 我 们 将 使 用 getNextSequenceValue 男 数 创建 一 个 新 的 文档 ， 并 设置 文档 _id 自动 为 
返回 的 序列 值 : 
>db.products.insert({ 
"_id":getNextSequenceVvalue("productid"), 
"product_name":"Apple iPhone", 
"category":"mobiles"}) 
>db.products.insert({ 
"_id":getNextSequenceVvalue("productid"), 


"product_name":"Samsung 53" , 
"category":"mobiles"}) 


就 如 你 所 看 到 的 ， 我 们 使 用 getNextSequenceValue 男 数 来 设置 _id 字段。 

为 了 验证 图 数 是 否 有 效 ， 我 们 可 以 使 用 以 下 命 合 读 取 文 档 : 
>db.prodcuts.find() 

以 上 命令 将 返回 以 下 结果 ， 我 们 发 现 _id 字段 是 自 增 长 的 : 


+ " 10" : 1，"product_name"” : "Apple iPhone", "category" : "mobiles"} 


+ " 10" : 2, "product_name" : "Samsung 53", "68560077" : "mobiles" 7 


免责 声明 


W3School 提 供 的 内 容 仅 用 于 培训 。 我 们 不 保证 内 容 的 正确 性 。 通 过 使 用 本 站 内 容 随 之 而 来 的 
风险 与 本 站 无 关 。W3School 简 体 中 文 版 的 所 有 内 容 仅 供 测试 ， 对 任何 法 律 问题 及 风险 不 承担 
任何 责任 。 


